又到每个月的15号了,现在avalon已经固定在每个月的15号发布新版本。这次发布又带来许多新特性,让大家写码更加轻松,借助于“操作数据即操作DOM”的核心理念与双向绑定机制,现在越来越多人加入到avalon的阵营中来。此外,基于avalon的UI库OniUI也越来越强大,很快,树组件也开发完毕,下星期也与大家见面了。到时,OniUI也有两个Grid组件,一个树组件的完整UI库。与本次发布的UI还有验证组件,mask组件,百叶窗切换组件……
UI库的广告就到时为止,我们看一下新版本带来的新特性与FIX BUG情况吧。
- 【新特征】ms-duplex绑定全面升级,脱胎换骨,如avalon.duplexHooks钩子对象,pipe内部方法。详看这里的例子。
- 【新特征】添加data-include-replace辅助指令 详见这里
- 【新特征】data-duplex-changed支持第二个参数data详见这里
- 【新特征】VM的$fire通信机制变成这个样式, all!xxx是不依赖于DOM树向周边VM发出通知; up!xxx与down!xxx是依赖于DOM向上方或向下方的VM发出通知,我们可以return false中止广播; 普通的xxx只能触发当前的VM的$watch回调。
- 【新特征】添加avalon.scanCallback,允许在某次扫描后触发这些回调。详见这里与这里的例子
avalon.scanCallback =
function
(fn, group) {
group = group ||
"$all"
var
array = scanObject[group] || (scanObject[group] = [])
array.push(fn)
}
avalon.scan =
function
(elem, vmodel, group) {
elem = elem || root
group = group ||
"$all"
//.....略
}
- 【优化】修正 $fire在跨模块通信时无法通知widget组件的BUG(添加了createSinalTower内部方法)
- 【优化】更改innerRequire内部方法的位置,及设置为空函数,方便用户移除“AMD加载器模块”后也能正常使用
- 【优化】精简IE6-8下input事件的模拟
- 【优化】精简 newSetter的逻辑详见这里
- 【优化】fix HTMLInputElement.prototype.value 的重写
- 【优化】重构notifySubscribers
- 【优化】fix getEachProxy BUG 详见这里
- 【优化】支持生成更多SVG元素
- 【优化】为对付firefox插件下严格的语法检测,使用全新的获取全局变量window的方法
- 【优化】修正 ms-src不能加载SWF BUG详见这里
- 【优化】修正ms-duplex 绑定VM某个子VM的属性,input值修改后没有同步到vm.$model的BUG 详见这里
- 【优化】修正avalon.mix方法拷贝VBScript对象时抛错的BUG 详见这里
- 【优化】修正IE6下因为for in循环导致isPlainObject不准的BUG 详见这里
- 【优化】将ms-if去掉的元素都移动head标签的avalon标签下详见这里
- 【优化】让date过滤器能像chrome那样支持更多日期格式详见这里
本次升级主打的是ms-duplex 2.0,大家可以到这里一窥其强大!ms-duplex2.0相对于旧的ms-duplex只能将element.value简单地同步到VM中,它添加了自动转换类型的功能(核心库),光标引导(avalon.mask),数据格式化(参看avalon.mask的第三个例子,将用户输入内容自动插入千分符),验证机制(avalon.validation)。
第二大新特性就添加了avalon.scanCallback这新方法,允许用户在扫描后进行操作。有了这东西,什么data-include-rendered, data-repeat-rendered, data-with-rendered就没有存在的必要了。以后它们内部全部用avalon.scanCallback实现。
从1.3.3起,我就着手开发静态收集依赖机制,以此为契机,发现许多要改良的地方,全部放到一个叫avalon.$events.js的版本上。但经过几个月的研究,发现静态收集依赖,是对压缩不友好的,像angular那样需要引入许多奇异的方式来规避这问题。因此我最终放弃这东西,以后改用其他方式提高性能。未来将着力升级三柱臣与avalon.observe.js。
三柱臣,动画mmAnimate,数据请求mmRequest,路由器mmRouter,现在就mmRequest最成熟,而mmRouter的需求则强烈,mmAnimate极需升级。它们三个都依赖了mmPromise,那是原生的Promise的一个包装,性能超好。
在chrome36 beta中,就已经存在element.animate这个方法,即引进了著名的web-animation。chrome39将进一步完善。新的mmAnimate也将基于它进行开发。
迷你MVVM框架在github的仓库https://github.com/RubyLouvre/avalon
avalon的新UI库地址OniUI, 多达42个UI,强大的换肤功能
朋友们用avalon做的东西
- 移动应用:读酷
- chrome插件:饭否客户端
- 为知笔记
- 金山WPS office 会员中心
- 稻売儿
- 桑夏资产官网
- 企业级应用:超博CRM客户关系管理系统(帐号:crm_ceo 密码:nncb_ceo)
- uliweb Python框架与avalon的组合示例
- avalon+jQuery实现域名注册查询
- 路由器示例
- 边锋活动页
- 记者考试题
- 基于avalonJS实现的2048游戏
相关推荐
一个迷你框架
本项目“Android mvvm 框架,最流行的mvvm demo”旨在提供一个无bug的示例,帮助开发者深入理解并实践MVVM框架在Android应用中的应用。 MVVM模式源于微软的WPF开发,近年来在Android开发中逐渐流行,它通过解耦视图...
**WPF轻量级MVVM框架入门2.1.2** 在Windows Presentation Foundation(WPF)开发中,MVVM(Model-View-ViewModel)模式是一种常见的设计模式,它有助于实现应用程序的视图与业务逻辑之间的解耦。MVVM通过数据绑定、...
**MVVM 框架详解** MVVM(Model-View-ViewModel)框架是现代软件开发中的一个重要概念,尤其在移动应用和Web应用开发中广泛使用。这个框架模式旨在提高应用程序的可测试性、可维护性和代码的解耦程度。在这个“MVVM...
Vue.js是一套构建用户界面的轻量级MVVM框架,与其他重量级框架不同的是, Vue.js 的核心库只关注视图层,并且非常容易学习,很容易与其它前端技术或已有的项目整合。 本系课程,主要分为两部分完成。第一部分:掌握...
首先从http://mvvmlight.codeplex.com/或者http://files.cnblogs.com/chengxingliang/GalaSoft.MvvmLight.V3.rar下载它的MVVM框架下来,安装上之后,...该程序是我学习MVVM框架学习制作的小示例,很适合mvvm框架入门。
**WPF MVVM框架Stylet使用教程 - 窗体交互用法** Windows Presentation Foundation (WPF) 是Microsoft提供的一种用于构建桌面应用程序的框架,它引入了Model-View-ViewModel (MVVM) 设计模式,使得UI设计和业务逻辑...
在IT行业中,MVVM(Model-View-ViewModel)框架是前端开发的重要组成部分,尤其是在JavaScript领域。MVVM模式是由Microsoft的WPF(Windows Presentation Foundation)引入的,后来在Web开发中得到了广泛应用,例如...
【标题】: "史上最全 MVVM 框架学习指南" 在 Android 开发领域,MVVM(Model-View-ViewModel)框架已经成为了现代应用程序设计的重要组成部分。本学习资源旨在提供全面深入的 MVVM 架构理解和实践指导,帮助开发者...
DevExpress MVVM框架是DevExpress提供的一个用于支持MVVM模式的开发框架,旨在简化使用DevExpress控件的MVVM应用程序开发。MVVM模式,即Model-View-ViewModel模式,是一种软件架构设计模式,通过分离用户界面的展示...
mvvm框架整合demo 在demo内有其他的实例,和其他实用框架有利于初学都学习,也有很多的代码注释
MVVM是一种流行的设计模式,尤其在WPF和Xamarin等框架中广泛应用,但在WinForm中相对较少见。然而,通过巧妙的实现,我们可以在WinForm上实现类似Vue的体验。 1. **MVVM模式概述**: MVVM模式分为三个主要部分:...
在本文中,我们将深入探讨如何在WinForm应用中利用MVVM框架,并且通过引入Castle动态代理来提升效率和代码复用性。标题“winform上的mvvm框架--升级版(动态代理)”揭示了我们将在WinForm环境中实现一个基于MVVM...
MVVM(Model-View-ViewModel)框架是一种设计模式,尤其在现代UI开发中,如WPF(Windows Presentation Foundation)和UWP(Universal Windows Platform)应用中广泛应用。它将应用程序的界面逻辑分离开来,使开发者...
这个框架引入了一种新的概念——Model-View-ViewModel(MVVM),使得开发人员能够更加高效地处理复杂的用户界面交互,同时保持代码的可维护性和测试性。 在传统的MVVM模式中,模型(Model)代表应用程序的数据,...
WPF中的MVVM框架提供了强大的工具和结构,帮助我们构建清晰、可维护的应用程序。通过"AlarmClock"实例,我们可以看到MVVM模式如何在实践中提升开发效率和代码质量。了解并熟练运用MVVM,对于任何WPF开发者来说都是至...
这个"ios-一个简单的MVVM框架.zip"文件可能包含了一个演示或实现MVVM模式的基本结构,帮助开发者更好地理解和应用这一模式。 MVVM模式的核心理念是将业务逻辑、数据和界面视图进行分离,以提高代码的可测试性和可...
**WPF采用MVVM框架实例** 在Windows Presentation Foundation(WPF)中,Model-View-ViewModel(MVVM)设计模式是一种广泛使用的架构模式,尤其适用于创建用户界面。它将业务逻辑、用户界面和数据绑定分离,使代码...
**WPF MVVM 开发框架详解** Windows Presentation Foundation (WPF) 是 Microsoft 推出的一种用于构建桌面应用程序的用户界面框架,它集成了丰富的图形、多媒体、数据绑定和控件库,为开发者提供了强大的设计和开发...
**Node.js与Moer.js:基于Proxy的全新MVVM框架** 在现代Web开发中,JavaScript框架扮演着至关重要的角色,它们极大地提高了开发效率并简化了前端应用的构建。Node.js作为一个强大的JavaScript运行环境,不仅在...