进入登录页时,用户名输入框自动聚焦、按enter键让密码框聚焦,完整输入信息后登录

让element-ui的输入框聚焦的4种方式

思路:(可以跳过这一步看完整代码——完整代码)

1. 进入页面时,用户名输入框就要获取焦点,使用 自定义指令 聚焦更方便。当然也可以用 ref 在 mounted() 钩子函数中让输入框聚焦。

mounted(){this.$nextTick(()=>{      this.$refs.userName.focus();});
}

2. 在用户输入框输入信息后,需要按 Enter 键,使下一个输入框聚焦,此时要用到按键事件。同时还要考虑按下 enter 键后,输入框内是否有值。如果没有值,那么就让用户输入框失去焦点,这一步的作用是让 element封装好的表单验证信息显示出来,然后再让用户输入框重新聚焦。

confirmInput(e){if(e.target.value !=""){e.target.blur();} else {e.target.blur();e.target.focus();}},

3. 用户在密码框输入密码后,要进行登录操作。同样要判断这个输入框是否有值。


在这里插入图片描述

完整代码:

<el-form :model="ruleForm" :rules="rules" ref="ruleForm" class="loginForm"><el-form-item prop="userName"><el-input type="text" size="medium" ref="userName"v-focus v-model="ruleForm.userName" @keyup.enter.native="confirmInput($event,false)"><template slot="prepend">用户名:</template></el-input></el-form-item><el-form-item prop="password"><el-input type="password" v-model="ruleForm.password"size="medium" ref="password"@keyup.enter.native="confirmInput($event,true)"><template slot="prepend">密码:</template></el-input></el-form-item><el-form-item class="checkboxItem"><el-checkbox label="记住密码"></el-checkbox></el-form-item><div class="submitBtn"><p @click="loginEnter">登 录</p></div>
</el-form><script>
data(){return {rules: {userName: [ { required: true, message: '请输入用户名', trigger: 'blur' } ],password: [ { required: true, message: '请输入密码', trigger: 'blur' } ]},ruleForm: {userName: "",password: ""}}
},
directives:{focus: {inserted: function(el){el.children[1].focus();}}},
methods: {//按Enter键//如果有多个输入框,可以在这一步多传入一个参数,//假设第三个参数是refName,在模板中传的是该输入框后一个要聚焦的输入框的ref值,并将这个值传给inputFocus(),作为第二个参数。//在inputFocus中,将this.$refs.password.focus();中的.password用[refName]来代替。confirmInput(e, isLogin){// 判断输入框是否有值,有的话失焦让另外一个输入框聚焦;// 没有就先失焦让提示显示出来,再重新聚焦(这样可以让element表单封装的验证信息显示出来)if(e.target.value !=""){e.target.blur();this.inputFocus(isLogin);} else {e.target.blur();e.target.focus();}},//通过isLogin这个参数来判断按下enter键后是否要调用登录接口inputFocus(isLogin){if(isLogin){this.loginEnter();} else {this.$refs.password.focus();}},// 登录loginEnter(){this.$refs.ruleForm.validate((valid) => {if (valid) {this.$router.replace('/productWarehouse/history');} else {alert('error submit!!');return false;}});}
}
</script>

示范一下如果有多个输入框的情况:

<el-input v-model="loginForm.userName" ref="userName" v-focus@keyup.enter.native="confirmInput($event,false, 'password')"placeholder="输入您的账号或手机号" class="nobr" autocomplete="off"
></el-input><el-input show-password v-model="loginForm.password" ref="password"@keyup.enter.native="confirmInput($event,netToken?true:false, 'codeInput')"placeholder="输入您的密码" class="nobr" autocomplete="off"
></el-input><el-input v-model="loginForm.validCode" ref="codeInput"@keyup.enter.native="confirmInput($event,true)"placeholder="输入验证码(忽略大小写)" class="nobr"
></el-input><script>//点击确认按钮confirmInput(e, isLogin, inputRef){if(e.target.value != ""){e.target.blur();this.inputFocus(isLogin, inputRef);} else {e.target.blur();e.target.focus();}},//isLogin=true表示登录inputFocus(isLogin, inputRef){if(isLogin){this.submitForm();} else {this.$refs[inputRef].focus();}},
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/362548.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JS的对象及其属性和方法

在JavaScript中是基于对象的编程&#xff0c;而不是完全的面向对象的编程。       那麽什麽是对象呢&#xff1f;如果你学过一些VB的编程&#xff0c;对这个名词一定不会陌生。通俗的说&#xff0c;对象是变量的集合体&#xff0c;对象提供对于数据的一致的组织手段&…

vue-cli安装步骤

vue-cli脚手架模板是基于node下的npm来完成安装的所以首先需要安装node 条件&#xff1a; node在4.以上&#xff0c;npm在3以上 安装 指令&#xff1a; 1、 npm install -g vue-cli在全局下安装vue-cli # 安装 vue-cli npm install -g vue-cli# 初始化 webpack 项目 vue in…

# reverse swap

目录&#xff1a; swap&#xff08;数字、字符串、&#xff09;reverseStringreverseWordsswap /** 借助临时变量 */ function swap(str1, str2) {const temp str1;str1 str2;str2 temp; } /** 解构赋值 */ [a, b] [b, a];/** 对象 */ {a,b} {a:b,b:a} /** 加法 只适用于…

使用Java编写简单的老虎机游戏

无论游戏多么简单或复杂 &#xff0c;Java都能胜任&#xff01; 在这篇文章中&#xff0c;让我们看一下Java编程的初学者如何制作一个简单而功能齐全的老虎机。 老虎机已经存在很长时间了&#xff0c;但是它的娱乐价值似乎并没有减弱。 InterCasino是第一个在1996年向世界提供…

类似flashget的浮动窗口的实现

作者&#xff1a;苍竹先生下载源代码一、简介&#xff1a;象flashget、迅雷、BT等都有浮动窗口&#xff0c;能详细地显示下载的详细信息&#xff0c;该类型的窗口有一下几个特点&#xff1a;1、窗口无标题栏&#xff0c;窗口的大小跟位图一样大。2、前端显示。3、在客户区内按下…

html笔记(二)html4+css2.0(元素类型、css精灵、宽度自适应、BFC、浏览器相关概述、css统筹)

大标题小节一、元素类型1. 元素分类2. 置换和非置换元素3. 元素类型转换二、css精灵三、宽高自适应1. 宽度自适应2. 高度自适应3. 最小高度自适应4. 高度塌陷及解决办法5. 元素的高度自适应屏幕的高度四、BEC概念应用1. 常见定位方案2. 触发BFC3. BFC特性及应用4. BFC概念五、浏…

25.C# 异步调用Web服务

1.创建Web服务 1.1VS新建ASP.Net空Web应用程序 1.2添加Web服务新建项 1.3添加GetWeather方法和相关类 using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Services; using System.EnterpriseServices;namespace WebServ…

css中单位的使用

css中许多的属性都需要添加长度&#xff0c;而长度一般由数字和单位构成&#xff0c;如1px,1.5em,2vh&#xff1b;也可以省略单位&#xff0c;如line-height:1.5,表示行高为字体大小的1.5倍&#xff1b; 长度单位一般也分为相对长度和绝对长度。 &#xff08;一&#xff09;绝…

Office开发程序集版本及部署问题

Office 开发遇到了OFFICE 2003和OFFICE 2007程序集兼容性的问题&#xff0c;使用OFFICE 11.DLL只能适应OFFICE 2003,Office 12.dll 能够兼容Office 2003和Office 2007。 以前部署时&#xff0c;是建议客户安装Office 2003。 今天看到《开发Office的一些应用部署后出现找不到程序…

OSGi:进入微服务架构的门户

在构建可扩展&#xff0c;可靠的分布式系统的背景下&#xff0c;“模块化”和“微服务体系结构”这两个术语如今经常出现。 众所周知&#xff0c;Java平台本身在模块化方面很弱&#xff08; Java 9将通过交付Jigsaw项目来解决这一问题&#xff09;&#xff0c;从而为OSGi和JBos…

新闻实时分析系统-Kafka分布式集群部署

Kafka是由LinkedIn开发的一个分布式的消息系统&#xff0c;使用Scala编写&#xff0c;它以可水平扩展和高吞吐率而被广泛使用。目前越来越多的开源分布式处理系统如Cloudera、Apache Storm、Spark都支持与Kafka集成。 1.下载Kafka并安装 1&#xff09;下载Apache版本的Kafka。 …

html笔记(五)2D、3D、3D动画

大标题小节一、2D1. css3 渐变的语法及应用2. 动画过渡&#xff1a;transition3. 2D转换属性&#xff1a;transform二、3D1. 3D转换2. 3D视距3. 3D翻转方法4. 3D位置移动5. 3D缩放三、3D动画1. keyframes2. 动画属性animation一、2D 1. css3 渐变的语法及应用&#xff1b; &a…

微信内置浏览器点击“返回”关闭窗口

场景&#xff1a;开发微信内的H5活动&#xff0c;需要进行微信授权&#xff0c;我们采用的是在一个静态页面&#xff08;只有js&#xff0c;所以是个空白页面&#xff09;内进行授权&#xff0c;授权后再跳转到活动主页。 客户需求&#xff1a;从活动主页返回时不显示这个授权…

dhl:mvc用户登陆身份验证

登录&#xff1a;[HttpPost]public ActionResult LoginSuccess() {bool rememberMe Request["rememberMe"].Contains("true"); UserAccount account ia.GetUserAccountByUserName(brief.UserName);//验证成功string usercookie account.UIN ",&qu…

基于上下文的访问控制

拓扑图 配置步骤 1配置端口ip地址&#xff0c;并检测连通性 服务器 ping pc端 服务器 telnet R3 2配置命令 R3(config)# ip access-list extended go R3(config-ext-nacl)# deny ip any any //此ACL目的是隔绝外网流量 R3(config-ext-nacl)# exit R3(config)# interface s0…

使用Gradle将JAR工件发布到Artifactory

因此&#xff0c;我浪费了一两天&#xff08;投资&#xff09;只是为了了解如何使用Gradle将JAR发布到本地运行的Artifactory服务器。 我使用Gradle Artifactory插件进行发布。 我迷失了无穷循环&#xff0c;包括各种版本的各种插件和执行各种任务。 是的&#xff0c;我之前阅读…

js 基础

1.注释 css: /* 这是一行单行注释 *//* 这个注释分散 在了多个物理 行上面 */  html: <!-- 注释内容 -->  JS: // 2.<a>标签中导航到同一个界面的不同位置  <p><a href"#C4">查看 Chapter 4。</a></p> <h2><…

Combox使用的一些技巧

这些天做一个小型的CMS&#xff0c;也就几张表&#xff0c;用WCFLINQ2SQLSilverlight这种方式开发的&#xff0c;对最常用的控件如DataGrid,DataForm以及Toolkit里其它一些控件的用法有了一定的了解&#xff0c;同时参照JV9的教程&#xff0c;把Silverlight里的验证机制仔细的学…

HTML+css实现的效果

一、鼠标划过效果 1. 类似电子书的图书效果2. 绝对定位实用案例 二、锚点的应用 三、css精灵&#xff08;图片整合&#xff09; 用一张图片写出一串电话号码用一张图片写出导航栏的滑动效果 四、后台管理布局 单飞布局双飞布局后台页面管理布局 五、css3部分 在一个div…

[LeetCode] Longest Substring Without Repeating Characters 最长无重复字符的子串 C++实现java实现...

最长无重复字符的子串 Given a string, find the length of the longest substring without repeating characters. Example 1: Input: "abcabcbb" Output: 3 Explanation: The answer is "abc", with the length of 3. Example 2: Input: "bbbbb&qu…