博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用avalon 实现一个序列号功能
阅读量:5955 次
发布时间:2019-06-19

本文共 1439 字,大约阅读时间需要 4 分钟。

“操作数据即操作DOM”的能力,让我们可以专致于业务,写出更专业,更优雅,更易维护的代码来。现在让我们看看如何实现一个序列号输入功能。它的需求以下:

  • 每输入4个字符就跳到下一个输入框。
  • 不能输入超过4个字符。
  • 支持复制贴粘功能,每4个字符自动对位到相应的输入框。

先给出代码:

                    

1234aaaabbbb6789

首先,我们要监听一个input里面的内容变化,马上能想到用ms-duplex,该绑定能逐字符地监听变化。但由于存在多个INPUT,为了方便循环处理,我们用到一个数组。但数组VM中只能监听它的长度变化。因此整成对象数组,然后监听这些对象的某个字符串属性就行了。

这个value值的变动,我们可以绑定$watch回调,当输入值超过4个字符串时,进行跳转操作。

el.$watch("value", function(a, b) {                    if (a.length >= 4) {                        model.focusIndex = index + 1 //跳转                        el.value = a.slice(0, 4)                    }                })

如果实现跳转操作呢,我们使用另一个新属性focusIndex 来监听,当它变化时,我们再调用一个跳转方法。而这个跳转方法需要得到元素节点。这唯有万能绑定ms-bind 能干这事。

ms-bind="vmProp:vmCallback"

vmCallback的this指向被绑定元素,并传入此绑定属性的前后两个值。vmProp的值每次变动都会调用vmCallback。

贴粘时,我们需要用到paste事件,但avalon默认没此绑定,需要用ms-on传入事件名,这里面做些兼容处理,逐一修改seriesNumber 数组对象的value 值就行了。

例子

1234aaaabbbb6789

整个流程简单利落,除了跳转时我们用到一些DOM方法,其他都是对数据的操作。这与以往jQuery, Prototype.js, YUI的实现思路完全不同。打个比喻,带来的技术体验,如同书法与打印机的区别。jQuery好优雅,能让你精确控制每一步DOM操作,DOM操作越是复杂,如同繁体字那样纵横捭阖,越是显得jQuery游刃有余。好干净,不要准备文房四宝,一张A4,一台打印机就行了,刷刷地出来你要的东西,干脆利落,没什么人情味,但效率奇高,是工业革命的先声。从历史的发展过程来看,书法这种讲究技术,渗杂着许多人个品味地艺术被整齐划一的印刷术逼到一死角,被剥夺了文化传承者的角色。jQuery这些也一样,DOM操作最快,也比不上MVVM这种印刷机般的技术,后者能不着痕迹地同步视图,里面精密的算法保证不会存在冗余无用的DOM操作。前者还存在“糟糕的书法者”问题,最好的笔砚,在某些人手里也是潦草不堪,看守打印机工作就没这问题。从势利的角度来看,就是怎么能够给资本家带来好处,怎么在相对时间内能够有更多更快, 更稳定的产出,就怎么快被采纳,人性使然。


相关文章

转载地址:http://hyexx.baihongyu.com/

你可能感兴趣的文章
修复群集无法切换磁盘问题
查看>>
expdp 详解及实例
查看>>
洛谷——P1495 曹冲养猪
查看>>
C++中 栈的简单封装
查看>>
我的友情链接
查看>>
Linux常用命令--iconv
查看>>
varnish的了解与常用配置使用
查看>>
Product user profile information 没有导入
查看>>
DELL T410服务器U盘安装Centos7
查看>>
解读最具O2O属性—哈根达斯微信企业号的成功之道
查看>>
Sqlserver2008日志压缩
查看>>
虚拟机usb无线上网同时主机本地上网或无线无线上网
查看>>
View的事件分发机制
查看>>
Android Ndef Message解析
查看>>
mysqldump backup script
查看>>
coding4fun比赛总结
查看>>
Windows Server 2003 系统安装
查看>>
庖丁解牛获取连接状态数的awk数组命令
查看>>
jQueryMobile新版中导航栏按钮消失的解决方法
查看>>
使用触发器记录oracle用户登陆信息
查看>>