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 相关文章推荐
一个简单的js鼠标划过切换效果
Jun 30 Javascript
Thinkphp模板没有解析直接原样输出的解决方法
Oct 31 Javascript
简单实现异步编程promise模式
Jul 31 Javascript
js实现刷新页面后回到记录时滚动条的位置【两种方案可选】
Dec 12 Javascript
利用JavaScript在网页实现八数码启发式A*算法动画效果
Apr 16 Javascript
通过源码分析Vue的双向数据绑定详解
Sep 24 Javascript
详解React之key的使用和实践
Sep 29 Javascript
解决vue-router 嵌套路由没反应的问题
Sep 22 Javascript
Ant design vue table 单击行选中 勾选checkbox教程
Oct 24 Javascript
JavaScript 防抖和节流遇见的奇怪问题及解决
Nov 20 Javascript
jQuery实现电梯导航模块
Dec 22 jQuery
js实现验证码干扰(动态)
Feb 23 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
php设计模式 Proxy (代理模式)
2011/06/26 PHP
php获取URL中带#号等特殊符号参数的解决方法
2014/09/02 PHP
HTML中嵌入PHP的简单方法
2016/02/16 PHP
初学prototype,发个JS接受URL参数的代码
2006/09/25 Javascript
JavaScript去掉空格的方法集合
2010/12/28 Javascript
IE与Firefox在JavaScript上的7个不同句法分享
2011/10/30 Javascript
jquery 滚动条事件简单实例
2013/07/12 Javascript
IE6-8中Date不支持toISOString的修复方法
2014/05/04 Javascript
Javascript的闭包详解
2014/12/26 Javascript
js实现拉幕效果的广告代码
2015/09/02 Javascript
Bootstrap入门书籍之(一)排版
2016/02/17 Javascript
基于BootStrap Metronic开发框架经验小结【一】框架总览及菜单模块的处理
2016/05/12 Javascript
基于jQuery实现仿微博发布框字数提示
2016/07/27 Javascript
AngularJS使用ng-options指令实现下拉框
2016/08/23 Javascript
Angularjs 实现一个幻灯片示例代码
2016/09/08 Javascript
微信小程序 教程之数据绑定
2016/10/18 Javascript
JS实现websocket长轮询实时消息提示的效果
2017/10/10 Javascript
sublime text配置node.js调试(图文教程)
2017/11/23 Javascript
Angular5升级RxJS到5.5.3报错:EmptyError: no elements in sequence的解决方法
2018/04/09 Javascript
vue input 输入校验字母数字组合且长度小于30的实现代码
2018/05/16 Javascript
微信小程序实现分享到朋友圈功能
2018/07/19 Javascript
JS实现的tab页切换效果完整示例
2018/12/18 Javascript
JS使用对象的defineProperty进行变量监控操作示例
2019/02/02 Javascript
[02:37]TI8勇士令状不朽珍藏II视频展示
2018/06/23 DOTA
利用matplotlib+numpy绘制多种绘图的方法实例
2017/05/03 Python
PyQt4实时显示文本内容GUI的示例
2019/06/14 Python
关于python字符串方法分类详解
2019/08/20 Python
Python字符串的15个基本操作(小结)
2021/02/03 Python
美国殿堂级滑板、冲浪、滑雪服装品牌:Volcom(钻石)
2017/04/20 全球购物
英国领先的瓷砖专家:Walls and Floors
2018/04/27 全球购物
食品销售计划书
2014/04/26 职场文书
公司建议书怎么写
2014/05/15 职场文书
2014员工聘用协议书(最新版)
2014/11/24 职场文书
工作违纪的检讨书范文
2019/07/09 职场文书
MySQL优化之如何写出高质量sql语句
2021/05/17 MySQL
Python如何使用循环结构和分支结构
2022/04/13 Python