本文的灵感是来自Halower的这篇博文,他是使用knockout与jQuery实现的。不过我觉得MVVM本来就强大的事件绑定功能,因此用jQuery 是多此一举。另,他也用了一些面向对象的写法。我个人认为,纯数据就该好好当纯数据,作为数据模型(M)而存在,想操作数据,则交由视图模型(VM)。在angularjs流行的一些成规,都是要求大家不要自己操作DOM,DOM是框架自行帮你偷偷搞定。这也与avalon一直提倡的“操作数据即操作DOM”的理念相符。由于avalon巧妙地利用了Object.defineProperty, __defineSetter__, __defineGetter__, VBScript等方法把等于号(=)重载了,因此与视图的同步就变得比其他MVVM更隐秘神奇。那么接着下来,让我们看看avalon是如何实现这个功能吧。

首先是视图层,里面的绑定属性其实可以在VM中的属性定了下来再添加。这也涉及MVVM另一个优势,分离关注点,因此切图与JS编程可以同时进行。由于JS代码不进行DOM操作,页面长得怎么样也无所谓,我又不需要选择器引擎!

        <div ms-controller="grid" class="grid" >
<div>
<p> <input ms-duplex="id">
<input ms-duplex="name">
<input ms-duplex="score" data-duplex-event="change"></p>
<p><button ms-click="add"> add</button></p>
</div>
<p>共{{array.size()}}条------------------合计{{total}}分</p>
<table>
<thead>
<tr>
<th>ID</th> <th>姓名</th> <th>分数</th> <th>操作</th>
</tr>
</thead> <tbody ms-each-el="array">
<tr>
<td>{{el.id}}</td>
<td>{{el.name}}</td>
<td>{{el.score}}</td>
<td align="center"><a ms-click="$remove" href="javascript:void(0)">移除</a></td>
</tr>
</tbody>
</table>
<textarea ms-value="JSON.stringify(array.$model)" style="width:90%;height:220px;"></textarea>
</div>

样式随便弄弄:

            .grid table{
border:1px solid #000;
width:500px;
border-collapse: collapse;
}
.grid button{
width:400px;
background: orange;
}
.grid table th, .grid table td{
border:1px solid #000;
padding: 2px 5px;
}

从HTML结构来看,分为两部分,一个是用于输入数据,另一个是呈现所有数据,数据上方还有个小统计。输入数据部分有三个输入项,我们对分数中进行校验,只保证其是数字就行了,目的是为了相加,因为input的value属性总为一个字符串类型。下方有个按钮,用于提交。呈现区为一个table,所有MVVM框架都支持数组循环输出,我的与angular走得很近。在循环区域,里面还内置一个$remove方法,用于删除监控数组中的某一个元素,这个比knockout人性化多了。下面是JS部分,你是看不到一句操作DOM的代码。

//如果大家对avalon不熟悉,可以参看这篇入门教程 http://www.cnblogs.com/rubylouvre/p/3181291.html
avalon.ready(function() {
var model = avalon.define('grid', function(vm) {
vm.id = ""
vm.name = ""
vm.score = 0
vm.total = 0

vm.add = function() {
if(vm.id && vm.name ){
vm.array.push({
id: vm.id,
name: vm.name,
score: vm.score
})
}
}
vm.array = []
});

model.$watch("score", function(a) {
var a = Number(a) || 0
a = a > 100 ? 100 : a

我们在define方法中定义了VM所有用到的数据,什么id, name, score, array, 还有需要绑到视图中的add方法。数据校验或数据变动时需要做的操作,我们是用$watch实现,它们被安排到define方法外,这是一个好主意。然后,就没有然后了!这就是MVVM的神奇之处,因为我们在视图中使用了{{}}, ms-click已经指明了它们的行为。因此当数据变动时,框架自然明白自己该什么做。

add

共{{array.size()}}条------------------合计{{total}}分

ID 姓名 分数 操作
{{el.id}} {{el.name}} {{el.score}} 移除

avalon.ready(function() {
var model = avalon.define('grid', function(vm) {
vm.id = ""
vm.name = ""
vm.score = 0
vm.total = 0

vm.add = function() {
if(vm.id && vm.name ){
vm.array.push({
id: vm.id,
name: vm.name,
score: vm.score
})
}
}
vm.array = []
});

model.$watch("score", function(a) {
var a = Number(a) || 0
a = a > 100 ? 100 : a

.grid table{
border:1px solid #000;
width:500px;
border-collapse: collapse;
}
.grid button{
width:400px;
background: orange;
}
.grid table th, .grid table td{
border:1px solid #000;
padding: 2px 5px;
}

目前我与5群的一些人已经将avalon应用于公司的生产环境,反应还是不错。虽然目前还不时冒出一些怪异的BUG,但难度不至于影响我们的进度,基本上半天就能修,比如说IE9-10的option标签的value问题,firefox 全系列下,未插入DOM树的元素的display样式取值问题,这是jQuery也没报到的新东西。有的话,我在做mass Framework时已经遇到过了。MVVM是一个全新的领域,要求对用户全面隐藏DOM操作,并将整个DOM树作为一个动态模板或数个复用的子模板,另外,DOM树其实也被我框架看作为一个Ioc容器的配置文件。如此种种,遭遇新的问题在所难免,但只要方向是对的,这就是康庄大道。虽然它与jQuery走的是一条截然不同的路,但明显优于jQuery。jQuery与DOM存在强依赖,导致维护成本奇高。这正是西方继jQuery后,又孜孜不倦发明backbone, canjs, knockout, emberjs, angular的原因。现在国内的技术步伐普通比外国慢两三年,现在前端MVVM已经在外国非常盛行,希望国人不要再落后太多了。

利用avalon 实现一个简单的成绩单的更多相关文章

  1. avalon实现一个简单的带增删改查的成绩单

    自从angular问世,一直就有去了解学习angular,一直想用angular去做一个项目,但无奈,大ng是国外产物,ng1.2版本就只兼容到IE8,1.3后的几个版本提升到IE9,据说NG2.0更 ...

  2. 利用ANTLR4实现一个简单的四则运算计算器

    利用ANTLR4实现一个简单的四则运算计算器 ANTLR4介绍 ANTLR能够自动地帮助你完成词法分析和语法分析的工作, 免去了手写去写词法分析器和语法分析器的麻烦 它是基于LL(k)的, 以递归下降 ...

  3. 利用 nodeJS 搭建一个简单的Web服务器(转)

    下面的代码演示如何利用 nodeJS 搭建一个简单的Web服务器: 1. 文件 WebServer.js: //-------------------------------------------- ...

  4. 利用VS2008发布一个简单的webservice

    一个开发好的webservice,怎样发布出去,供其他电脑访问呢? 本文将介绍如何发布一个简单的webservice,其中的内容都是在网上查看别人文章,自己仿照着做了一遍,因此,难免会发生错误,如果发 ...

  5. 利用java实现一个简单的远程监控程序

    一般的远程监控软件都是用c或者c++等语言开发的,而使用java如何来实现相同的功能呢. 首先我们先介绍一下一个简单的远程监控程序的实现原理. 功能一,远程屏幕监视 (1) 必须要有监控端与被监控端, ...

  6. 利用jmeter做一个简单的性能测试并进行参数化设置

    1.新增一个线程组,并在下面添加基本原件,包括:监听器.http请求默认值和一个事务控制器 在http请求默认值中填写 ip 地址和端口号,协议类型默认为http 2.添加代理服务器,以便之后进行录制 ...

  7. Asp.NetMVC利用LigerUI搭建一个简单的后台管理详解(函登录验证)

    上一篇 Asp.Net 中Grid详解两种方法使用LigerUI加载数据库数据填充数据分页  了解了LigerUI 中Grid的基本用法  现在结合上一篇的内容做一个简单的后台管理,当然也有前台的页面 ...

  8. 利用OD破解一个简单的C语言程序

    最近在学习汇编(看的是王爽老师的<汇编语言(第三版)>),然后想尝试使用OD(Ollydbg)软件破解一个简单的C语言程序练练手. 环境: C语言编译环境:VC++6.0 系统:在Wind ...

  9. 利用 Docker 构建一个简单的 java 开发编译环境

    目前 Java 语言的版本很多,除了常用的 Java 8,有一些遗留项目可能使用了 Java 7,也可能有一些比较新的的项目使用了 Java 10 以上的版本.如果想切换自己本地的 Java 开发环境 ...

随机推荐

  1. ue4 NewObject/StaticConstructObject_Internal/StaticAllocateObject/FObjectInitializer:对象创建和初始化

    UObject是一套很复杂的体系,之前读ue3代码时曾分析过其类型系统实现,主要是与UClass间的关系 现在转到ue4,发现那一块其实差不多,于是再重点备忘一下UObject本身的创建和初始化过程 ...

  2. Q_OBJECT

    所有QObject的派生类在官方文档中都推荐在头文件中放置宏Q_OBJECT,那么该宏到底为我们做了哪些工作?在qobjectdef.h中有下面的代码: #define Q_OBJECT \ publ ...

  3. K/3 Cloud开发之旅 -- 主页自定义篇(一)

    如果说我们要进行主页自定义篇,首先涉及到的就是登陆的自定义,那么如何进行登录界面的自定义呢 其实登陆界面自定义主要就是图片的替换 ,那么我们就看下登陆界面的图片的组成 登录页面底图有两部分组成,一个是 ...

  4. tomcat的CATALINA_HOME可以不用设置

    不配置tomcat的环境变量也是可以运行的 用记事本打开tomcat/bin目录下面的startup.bat 在文本的前一部分有下面的脚本代码 rem Guess CATALINA_HOME if n ...

  5. img 是内联元素

    图片是内联元素 ,同时是内联替换元素(替换元素是能设置宽和高的) 取消图片的magin display:block;(一般初始化标签中会把图片设置成块状) replaced element <i ...

  6. eclipse远程调试Hadoop

    环境需求: 系统:window 10 eclipse版本:Mars Hadoop版本:2.6.0 资源需求:解压后的Hadoop-2.6.0,原压缩包自行下载:下载地址 丑话前头说: 以下的操作中,e ...

  7. Win7 64位命令行编译cuda及设置Windows显卡响应时间

    在开始菜单中找到Visual Studio 2013 >> Visual Studio Tools 选择86或64版本的VC命令提示符环境,我用的 VS2013 x86 Native To ...

  8. 浅谈城市规划在移动GIS方面的应用发展

    1.概述 城市建设进程加快,城市规划管理工作日趋繁重,各种来源的数据产生各种层出不穷的问题,严重影响城市规划时的准确性,为此全面合理的掌握好各方面的城市规划资料才能做出更加科学的决策.移动端的兴起为规 ...

  9. jQuery中给动态添加的元素绑定事件

    $(document).on(event,selector,function(){ //do somethimg here! });

  10. 绿色ip扫描工具

    ip扫描,可以扫描一下自己的局域网有多少设备在线,有没有在蹭网.优点在于:短小精悍,快速,不用安装. 其实,我自己也写过一个但是没有这个精致,感兴趣的可以一起讨论. 下载地址:32位 64位 我的淘宝 ...