浏览 2206 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2010-03-08
最后修改:2010-04-05
支持change事件以便监视属性的变化,此外,还可以自定义属性的setter、getter和校验 方法,可以定义属性为只读或者一次写(write-once) 1. 要使用Attribute,首先要引入YUI3的种子文件: <script src="http://yui.yahooapis.com/3.0.0/build/yui/yui-min.js"></script> 然后加载相应模块: YUI().use('attribute', function(Y) { }); 2. Attribute类是用来扩张一个既存的类,使其具有属性管理功能的,以下是将MyClass扩张 的示例代码: YUI().use("attribute", function(Y) { function MyClass() { ... } Y.augment(MyClass, Y.Attribute); }); 3. 增加属性 一旦一个类扩张了Attribute功能,就可以使用addAttrs批量添加属性,或者使用addAttr一个一 个地添加属性,以下是批量添加的例子: function MyClass(userValues) { var attributeConfig = { attrA : { // attrA的配置,可配置的属性参见【4.属性配置属性】 }, attrB : { // attrB的配置 } }; this.addAttrs(attributeConfig, userValues); }; 可以在new这个类或者new之后用set方法对属性赋值: var o = new MyClass({ attrA:5 }); o.set("attrB", "Hello World!"); 4. 属性配置属性(Attribute configuration properties) 可以对属性(Attribute)进行配置的属性(properties)参见下表,所有属性都是可选的,也是 大小写敏感的: value: 默认值 valueFn:函数。返回值会被作为属性的值 getter:函数 setter:函数 validator:函数。在setter前被调用,用来校验数据 readOnly:布尔值 writeOnce:布尔值。0-不广播;1-广播到YUI实例;2-广播到YUI实例和YUI global lazyAdd:布尔值 cloneDefaultValue:可以为"shallow", "deep", true, false。仅在Base的ATTRS中使用。 以下是在addAttr中使用的例子: this.addAttr("attrA", { value: 5, setter: function(val) { return Math.min(val, 10); }, validator: function(val) { return Y.Lang.isNumber(val); } }); 5. 属性变化事件 属性变化事件是一种用户自定义事件,其类型为"[attributeName]Change",例如定义了一个 属性"attrA",那么它的变化事件就是"attrAChange"。 定义事件监听器时可以使用两种方法:on和after。其中用on注册的监听器在变化发生前调用, 我们可以在这里检查数据的合法性,并用Event的preventDefault()方法拒绝对属性的修改。而 用after注册的监听器在事件发生后调用。 以下是对属性"enabled"定义变化事件监听器的示例代码: o.on("enabledChange", function(event) { ... }); o.after("enabledChange", function(event) { ... }); 事件监听器的第一个参数是以Event对象,它具有以下的属性和方法: newVal prevVal attrName subAttrName preventDefault() stopImmediatePropagation():可以在on和after监听器中使用,用于停止事件在监听器栈中的传播 6. 属性设置流程图(很值得参考) 7. 子属性(sub attribute) 属性可以包含子属性,我们可以在set/get方法中使用由"."标识的完整属性名来操作子属性。 以下是set的例子: o.set("strings", { ui : { accept_label : "OK", decline_label : "Cancel", }, errors : { e1000 : "Not Supported", e1001 : "Network Error" } }); o.set("strings.ui.accept_label", "Yes"); o.set("strings.ui.decline_label", "No"); 以下是get的例子: var lbl = o.get("strings.ui.accept_label"); 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |