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

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

先给出代码:


<!DOCTYPE html>
<html>
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script src="avalon.js"></script>
<style>
input:focus{
border: 1px solid #a9ea00;
background:#f0f0f0;
}
</style>
<script>
var model = avalon.define("xxx", function(vm) {
vm.seriesNumber = [{value: ""}, {value: ""}, {value: ""}, {value: ""}]
vm.focusIndex = NaN
//获得焦点,实现输入框中的跳转操作
vm.focus = function(a, b) {
var el = this;
if (a === avalon(el).data("index")) {
setTimeout(function() {
el.focus()
el.select();
}, 0);
}
}
vm._focus = function() {
model.$unwatch()
model.focusIndex = avalon(this).data("index")
model.$watch()
} //通过贴粘实现智能输入
vm.paste = function(e) {
var index = avalon(this).data("index")
var text = ""
if (e.clipboardData) {
avalon.log("w3c")
text = e.clipboardData.getData("text/plain");
} else if (window.clipboardData) {
avalon.log("ie")
text = clipboardData.getData("Text")
}
var array = text.match(/\w{4}/g) || []
for (var i = 0; i = 4) {
model.focusIndex = index + 1 //跳转
el.value = a.slice(0, 4)
}
})
})
//刚开始时聚焦到第一个输入框中
avalon.ready(function() {
model.focusIndex = 0
}) </script>
</head>
<body>
<div ms-controller="xxx" ms-each-el="seriesNumber">
<input ms-duplex="el.value" ms-on-paste="paste" ms-focus="_focus" ms-bind="focusIndex: focus" ms-data-index="$index">
</div>
<h2>1234aaaabbbb6789</h2>
</body>
</html>

首先,我们要监听一个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 值就行了。

var model = avalon.define("xxx", function(vm) {
vm.seriesNumber = [{value: ""}, {value: ""}, {value: ""}, {value: ""}]
vm.focusIndex = NaN
//获得焦点,实现输入框中的跳转操作
vm.focus = function(a, b) {
var el = this;
if (a === avalon(el).data("index")) {
setTimeout(function() {
el.focus()
el.select();
}, 0);
}
}
vm._focus = function() {
model.$unwatch()
model.focusIndex = avalon(this).data("index")
model.$watch()
}

//通过贴粘实现智能输入
vm.paste = function(e) {
var index = avalon(this).data("index")
var text = ""
if (e.clipboardData) {
avalon.log("w3c")
text = e.clipboardData.getData("text/plain");
} else if (window.clipboardData) {
avalon.log("ie")
text = clipboardData.getData("Text")
}
var array = text.match(/\w{4}/g) || []
for (var i = 0; i = 4) {
model.focusIndex = index + 1 //跳转
el.value = a.slice(0, 4)
}
})
})
//刚开始时聚焦到第一个输入框中
avalon.ready(function() {
model.focusIndex = 0
})

fieldset input:focus{
border: 1px solid #a9ea00;
background:#f0f0f0;
}

例子

1234aaaabbbb6789

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


相关文章

利用avalon 实现一个简单的成绩单

使用avalon 实现一个序列号功能的更多相关文章

  1. OpenResty 是一个全功能的 Web 应用服务器

    OpenResty (也称为 ngx_openresty)是一个全功能的 Web 应用服务器.它打包了标准的 Nginx 核心,很多的常用的第三方模块,以及它们的大多数依赖项. 通过众多进行良好设计的 ...

  2. php大力力 [042节] 今天做了一个删除功能

    php大力力 [042节] 今天做了一个删除功能 if(isset($_GET['action'])){ if($_GET['action']=="del"){ $sql = &q ...

  3. 为Pythonic论坛添加一个“专题”功能(续)

    上篇博文<为Pythonic论坛添加一个“专题”功能>,在模板的层次上对发帖进行了限制.也就是根据用户是否拥有权限来决定是否显示发帖框. 但是自从这么“投机取巧”的写完模板后,整夜辗转反侧 ...

  4. Office365开发系列——开发一个全功能的Word Add-In

    2016年10月我参加了在北京举行的DevDays Asia 2016 - Office 365应用开发”48小时黑客马拉松“,我开发的一个Word Add-In Demo——WordTemplate ...

  5. CustomDialog——一个多功能、通用、可自定义的Dialog

    CustomDialog--一个多功能.通用.可自定义的Dialog  依赖 compile 'com.github.SiberiaDante:CustomDialog:v1.0.1'  说明[Cus ...

  6. Spring Boot 2.2 增加了一个新功能,启动飞起~

    前几天栈长分享了一个好玩的框架:一个比Spring Boot快44倍的Java框架!,是不是感觉 Spring Boot 略慢?今天讲一下 Spring Boot 添加的这个新特性,可以大大提升 Sp ...

  7. PHP操作实现一个多功能购物网站

    PHP操作实现一个多功能购物网站 一.需要实现的页面: Index.aspx:浏览商品页面,显示商品列表,用户可以点击“加入购物车“. ViewCart.aspx:查看购物车页面,显示已购买的商品信息 ...

  8. Android Studio 通过一个登录功能介绍SQLite数据库的使用

    前言: SQLite简介:是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中.它是D.RichardHipp建立的公有领域项目.它的设计目标是嵌入式的,而且目前已经在 ...

  9. 项目中的一个分页功能pagination

    项目中的一个分页功能pagination <script> //总页数 ; ; //分页总数量 $(function () { // $("#pagination"). ...

随机推荐

  1. POJ1741 Tree + BZOJ1468 Tree 【点分治】

    POJ1741 Tree + BZOJ1468 Tree Description Give a tree with n vertices,each edge has a length(positive ...

  2. flask第十九篇——模板【3】

    请关注微信公众号:自动化测试实战 今天我们继续模板的知识,现在我们增加字典的复杂度,这个时候在render_template第二个参数可以传**title,以后我们会用**context代替原来的ti ...

  3. Web API的发布问题

    配置“ISAPI 和 CGI 限制”的4.0版本设置为允许,要不然出现“由于 Web 服务器上的“ISAPI 和 CGI 限制”列表设置,无法提供您请求的页面.”的错误. “An error has ...

  4. vue a href="tel" 拨打电话

    走默认的方式失败 <a href="tel:{{telPhone}}">{{telPhone}}</a> 走字符串拼接方法成功 <a :href=&q ...

  5. 数据库的备份与恢复(oracle 11g) (转)

    一.       内容与步骤 (注意这里许多步骤需要同学们查资料,理解并消化后才能完成) 1.数据库创建 (1)   安装Oralce11g: (2)   创建至少两个以上用户: (3)   每个用户 ...

  6. 坑爹的AMH

    坑爹的 AMH的配置文件在这里: nginx 配置文件1:/usr/local/nginx-generic-1.6/conf/nginx.conf nginx 配置文件2:/home/wwwroot/ ...

  7. Python WebServer with MSSql

    今天尝试了一下在windows上用python来写web服务 我的环境是 win7(64位)+ python(2.7.11) 第一步需要安装pymssql 第二步需要安装tornado(web服务靠他 ...

  8. Unit02: CSS 概述 、 CSS 语法 、 CSS 选择器 、 CSS声明

    Unit02: CSS 概述 . CSS 语法 . CSS 选择器 . CSS声明 my.css p { color: yellow; } demo1.html <!DOCTYPE html&g ...

  9. JAVA-Unit04: SQL(高级查询)

    Unit04: SQL(高级查询) 查看SMITH的上司在那个城市工作? SELECT e.ename,m.ename,d.loc FROM emp e,emp m,dept d WHERE e.mg ...

  10. linux保存的设置用户/组ID(set-user-ID)的测试

    直接贴代码和结果 // FileName: id.cpp #include <iostream> #include <unistd.h> using namespace std ...