Vue2.x Todo之自定义指令实现自动聚焦的方法


Posted in Javascript onJanuary 08, 2019

我们希望用户双击 todo 进入编辑状态后输入框自动获取焦点,而不是需要先手动点一下。input 元素有一个 focus 方法可以来帮我们完成这个事情,但现在的问题是如何在 Vue 中获得这个 input 元素,从而来操作它。Vue 的自定义指令可以完成这个功能。

我们先来看看 Vue 官网的一个示例:

然而,有的情况下,你仍然需要对普通 DOM 元素进行底层操作,这时候就会用到自定义指令。举个聚焦输入框的例子,如下:

一个输入框:

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

// 注册一个全局自定义指令 `v-focus` 

Vue.directive('focus', { // 当被绑定的元素插入到 DOM 中时…… inserted: function (el) { // 聚焦元素 el.focus() } })

如果想注册局部指令,组件中也接受一个 directives 的选项:

directives: { focus: { // 指令的定义 inserted: function (el) { el.focus() } } }

指令是什么,就是用来指导被绑定的元素的行为,我们之前接触过 v-if、v-model、v-bind 等指令,官方文档说的非常清楚,我们可以自己注册一个指令,然后实现某些钩子函数,从而指定被绑定元素的行为。这里我们依葫芦画瓢,实现一个 focus 指令,这个指令实现了 inserted 钩子函数,这个函数在被绑定的元素被插入 dom 时触发,且被绑定的元素会作为参数传入钩子函数,我们就可以在函数中对它操作。

我们在 Vue 对象中声明局部指令:

<script>
  let id = 0; // 用于 id 生成
  var app = new Vue({
    ...
    methods: {
      ...
    },
    directives: {
      focus: {
        inserted: function (el) {
          el.focus()
        }
      }
    }
  })
</script>

然后就可以使用这个指令了,把它绑定到编辑框,这样编辑框出现时指令就被触发,从而聚焦。

<input type="text" 
    value="编辑 todo..."
    v-focus="true"
    v-if="editedTodo!==null && editedTodo.id===todo.id"
    v-model="todo.title"
    @keyup.enter="editDone(todo)"
    @keyup.esc="cancelEdit(todo)"/>

注意因为元素一旦出现一定要聚焦的,所以条件始终为 true。

现在用户体验好多了!快打开浏览器体验一下吧!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 一行代码,轻松搞定浮动快捷留言-V2升级版
Apr 02 Javascript
jQuery 限制输入字符串长度
Jun 20 Javascript
JS监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
Aug 05 Javascript
利用vue-router实现二级菜单内容转换
Nov 30 Javascript
JavaScript 中 apply 、call 的详解
Mar 21 Javascript
AngularJS表单验证功能分析
May 26 Javascript
微信小程序 监听手势滑动切换页面实例详解
Jun 15 Javascript
Bootstrap 模态框(Modal)带参数传值实例
Aug 20 Javascript
利用JQuery操作iframe父页面、子页面的元素和方法汇总
Sep 10 jQuery
vue2.0移动端滑动事件vue-touch的实例代码
Nov 27 Javascript
vue+eslint+vscode配置教程
Aug 09 Javascript
highcharts.js数据绑定方式代码实例
Nov 13 Javascript
关于React动态加载路由处理的相关问题
Jan 07 #Javascript
vue+iview 兼容IE11浏览器的实现方法
Jan 07 #Javascript
详解Vue iview IE浏览器不兼容报错(Iview Bable polyfill)
Jan 07 #Javascript
利用React Router4实现的服务端直出渲染(SSR)
Jan 07 #Javascript
Node.js EventEmmitter事件监听器用法实例分析
Jan 07 #Javascript
小程序二次贝塞尔曲线实现购物车商品曲线飞入效果
Jan 07 #Javascript
jQuery实现的别踩白块小游戏完整示例
Jan 07 #jQuery
You might like
异世界新番又来了,同样是从零开始,男主的年龄降到5岁
2020/04/09 日漫
PHP 的 __FILE__ 常量
2007/01/15 PHP
PHP iconv 解决utf-8和gb2312编码转换问题
2010/04/12 PHP
php使用sql数据库 获取字段问题介绍
2013/08/12 PHP
PHP基于CURL进行POST数据上传实例
2014/11/10 PHP
PHP代码实现表单数据验证类
2015/07/28 PHP
Laravel jwt 多表(多用户端)验证隔离的实现
2019/12/18 PHP
PHP如何防止用户重复提交表单
2020/12/09 PHP
IE6 hack for js 集锦
2014/09/23 Javascript
js防止DIV布局滚动时闪动的解决方法
2014/10/30 Javascript
javascript笛卡尔积算法实现方法
2015/04/08 Javascript
轻松掌握JavaScript中介者模式
2016/08/26 Javascript
使用jQuery卸载全部事件的思路详解
2017/04/03 jQuery
JavaScript实现的搜索及高亮显示功能示例
2017/08/14 Javascript
nodejs使用express获取get和post传值及session验证的方法
2017/11/09 NodeJs
Vue项目组件化工程开发实践方案
2018/01/09 Javascript
Vue源码学习之关于对Array的数据侦听实现
2019/04/23 Javascript
jQuery Ajax async=&gt;false异步改为同步时,解决导致浏览器假死的问题
2019/07/22 jQuery
vue 源码解析之虚拟Dom-render
2019/08/26 Javascript
在Layui中实现开关按钮的效果实例
2019/09/29 Javascript
Python里disconnect UDP套接字的方法
2015/04/23 Python
Python中内置数据类型list,tuple,dict,set的区别和用法
2015/12/14 Python
Python抓取框架 Scrapy的架构
2016/08/12 Python
python最长回文串算法
2018/06/04 Python
Python3 SSH远程连接服务器的方法示例
2018/12/29 Python
基于Python词云分析政府工作报告关键词
2020/06/02 Python
pandas针对excel处理的实现
2021/01/15 Python
英国翻新电子产品购物网站:Tech Trade
2017/12/25 全球购物
Android笔试题总结
2014/11/29 面试题
自我推荐书
2013/12/04 职场文书
党校培训思想汇报
2013/12/30 职场文书
农村婚庆司仪主持词
2014/03/15 职场文书
小学生国庆演讲稿
2014/09/05 职场文书
健康状况证明书
2014/11/26 职场文书
同学聚会通知书
2015/04/20 职场文书
Java 常见的限流算法详细分析并实现
2022/04/07 Java/Android