快速解决element的autofocus失效问题


Posted in Javascript onSeptember 08, 2020

原因:

autofocus是vue中input的原生属性,element也支持这种方法,

但是element中的el-input组件外面还有其他组件, 导致autofocus失效, 只能手动调用focus方法来聚集。

方法:

绑定ref

<el-input ref="myNameId" v-model="form.name" />

this.$refs.myNameId.focus();

动态绑定ref

<el-input :ref=" 'input'+ form.id " v-model="form.name" />

this.$nextTick(()=>{
 let id = 'input'+this.form.id;
 this.$refs[id].focus();
})

补充知识:element input输入框自动获取焦点

最近项目中在做表单的时候,需要自动滚动到评论框,并且让评论框自动聚焦,这就需要手动触发输入框的 focus 状态。

但是,element并不支持autofocus属性,那就只能通过原生的js效果获取聚焦效果了

document.getElementById("input").focus();

或者利用vue的ref属性也可以实现聚焦效果:

原理其实很简单,Element 已经提供了 focus 方法,但是文档并没有写明如何去调用,下面是在el-input标签上加入ref属性,然后在需要的地方直接调用方法就可以了

<el-input v-model="input" placeholder="请输入内容" ref="input"></el-input>

this.$nextTick(() => {
  this.$refs.input.focus()
 })

注意:一个页面只能有一个聚焦效果

last , vue也支持自定义指令

当页面加载时,该元素将获得焦点 (注意:autofocus 在移动版 Safari 上不工作)。事实上,只要你在打开这个页面后还没点击过任何内容,这个输入框就应当还是处于聚焦状态。现在让我们用指令来实现这个功能:

// 注册一个全局自定义指令 `v-focus`
Vue.directive('focus', {
 // 当被绑定的元素插入到 DOM 中时……
 inserted: function (el) {
 // 聚焦元素
 el.focus()
 // element-ui
 el.children[0].focus()
 // 元素有变化,如show或者父元素变化可以加延时或判断
 setTimeout(_ => {
  el.children[0].focus()
 })
 }
})

以上这篇快速解决element的autofocus失效问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery 操作DOM的基本用法分享
Apr 05 Javascript
关于jquery input textare 事件绑定及用法学习
Apr 03 Javascript
jquery+css+ul模拟列表菜单具体实现思路
Apr 15 Javascript
Jquery动态替换div内容及动态展示的方法
Jan 23 Javascript
JavaScript入门基础
Aug 12 Javascript
Node.js与Sails ~项目结构与Mvc实现及日志机制
Oct 14 Javascript
浅谈toLowerCase和toLocaleLowerCase的区别
Aug 15 Javascript
解决vue中post方式提交数据后台无法接收的问题
Aug 11 Javascript
详解react native页面间传递数据的几种方式
Nov 07 Javascript
Vue动态路由缓存不相互影响的解决办法
Feb 19 Javascript
koa+mongoose实现简单增删改查接口的示例代码
May 13 Javascript
vue 遮罩层阻止默认滚动事件操作
Jul 28 Javascript
vue axios请求成功却进入catch的原因分析
Sep 08 #Javascript
JavaScript数组类型Array相关的属性与方法详解
Sep 08 #Javascript
vue中后端做Excel导出功能返回数据流前端的处理操作
Sep 08 #Javascript
vue等两个接口都返回结果再执行下一步的实例
Sep 08 #Javascript
基于postman获取动态数据过程详解
Sep 08 #Javascript
解决vue请求接口第一次成功,第二次失败问题
Sep 08 #Javascript
如何区分vue中的v-show 与 v-if
Sep 08 #Javascript
You might like
PHP中用header图片地址 简单隐藏图片源地址
2008/04/09 PHP
将数组写入txt文件 var_export
2009/04/21 PHP
php中apc缓存使用示例
2013/12/25 PHP
PHP实现手机号码中间四位用星号(*)隐藏的自定义函数分享
2014/09/27 PHP
php递归函数三种实现方法及如何实现数字累加
2015/08/07 PHP
PHP+fiddler抓包采集微信文章阅读数点赞数的思路详解
2019/12/20 PHP
一个级联菜单代码学习及removeClass与addClass的应用
2013/01/24 Javascript
杨氏矩阵查找的JS代码
2013/03/21 Javascript
基于JQuery实现滚动到页面底端时自动加载更多信息
2014/01/31 Javascript
jQuery实现鼠标经过图片变亮其他变暗效果
2015/05/08 Javascript
自己动手写的javascript前端等待控件
2015/10/30 Javascript
javascript字符串替换函数如何一次性全部替换掉
2015/10/30 Javascript
JS鼠标拖拽实例分析
2015/11/23 Javascript
浅谈js常用内置方法和对象
2016/09/24 Javascript
JS正则子匹配实例分析
2016/12/22 Javascript
node.js使用redis储存session的方法
2018/09/26 Javascript
JavaScript栈和队列相关操作与实现方法详解
2018/12/07 Javascript
简述Python中的面向对象编程的概念
2015/04/27 Python
Python实现简易版的Web服务器(推荐)
2018/01/29 Python
Python cv2 图像自适应灰度直方图均衡化处理方法
2018/12/07 Python
Python创建一个元素都为0的列表实例
2019/11/28 Python
利用python读取YUV文件 转RGB 8bit/10bit通用
2019/12/09 Python
深入浅析python变量加逗号,的含义
2020/02/22 Python
python实现从ftp服务器下载文件
2020/03/03 Python
Python Socketserver实现FTP文件上传下载代码实例
2020/03/27 Python
python读取配置文件方式(ini、yaml、xml)
2020/04/09 Python
澳大利亚顶级美发和美容贸易超市:glamaCo
2020/01/19 全球购物
澳洲最大的时尚奢侈品电商平台:Cettire
2020/06/15 全球购物
精彩广告词大全
2014/03/19 职场文书
投资意向书范本
2014/04/01 职场文书
啦啦队口号大全
2014/06/16 职场文书
机关副主任个人四风问题整改措施
2014/09/26 职场文书
院系推荐意见
2015/06/05 职场文书
php 解析非标准json、非规范json
2021/04/01 PHP
Java 在线考试云平台的实现
2021/11/23 Java/Android
MYSQL常用函数介绍
2022/05/05 MySQL