中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 使用YUI 3開發(fā)Web應(yīng)用的訣竅
重新認(rèn)識(shí)CSS的權(quán)重 回到列表 firebug net面板詳解
 使用YUI 3開發(fā)Web應(yīng)用的訣竅

作者:拔赤 時(shí)間: 2011-04-18 文檔類型:翻譯 來自:Taobao.com UED Team

第 1 頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [1]
第 2 頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [2]
第 3 頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [3]
第 4 頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [4]
第 5 頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [5]
第 6 頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [6]
第 7 頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [7]
第 8 頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [8]
第 9 頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [9]

配置屬性

靜態(tài)成員中最重要的就是ATTRS,其中列出了你的類所需的所有配置參數(shù)。例如你需要一個(gè)名為value的成員,這個(gè)成員用于保存一個(gè)數(shù)字,默認(rèn)初始值為0,可以這樣傳入第五個(gè)參數(shù)。

ATTRS: {
    value: {
        value: 0,
        validator: Lang.isNumber
    }
}

ATTRS中當(dāng)然可以寫入多個(gè)成員,每個(gè)成員都下轄各自的配置項(xiàng),通過閱讀addAttr()來了解更多參數(shù)配置。我們看到,validator使用了之前代碼中定義的縮寫Lang,驗(yàn)證函數(shù)得到一個(gè)實(shí)參的輸入,返回一個(gè)布爾值,所有的Y.Lang.isXxxx都可以作為校驗(yàn)函數(shù),當(dāng)然,為了更嚴(yán)格細(xì)致的校驗(yàn),你可能需要定義新的validator、setter和getter,這里推薦使用字符串作為句柄賦值給validator、setter或者getter,Attribute會(huì)將字符串對應(yīng)到具體的函數(shù)。比如要定義一個(gè)validCodes屬性,可以接收單個(gè)值或者一個(gè)數(shù)組,但應(yīng)當(dāng)統(tǒng)一返回一個(gè)數(shù)組:

ATTRS: {
    validCodes: {
        setter: ‘_setValidCodes’
    }
}

我們需要在Y.Base.create()的第四個(gè)參數(shù)中聲明_setValidCodes方法,其他的成員也可以在這里追加聲明。

_setValidCodes: function (value) {
    if (!Lang.isArray(value)) {
        value = [ value ];
    }
    return value;
}

除非函數(shù)足夠簡單,最好單獨(dú)重寫setter、setter和validator,傳入他們的函數(shù)名作為實(shí)參,讓Attribute將函數(shù)名對應(yīng)到真實(shí)的函數(shù)。

總之,使用setter作為標(biāo)準(zhǔn)輸入,這樣會(huì)為組件帶來一些非常有用的特性。比如配置項(xiàng)值的改變會(huì)觸發(fā)beforeChange和afterChange事件,如果在beforeChange事件中停止事件,則可以阻止屬性的更改,因此組件實(shí)例生成后,請善用自定義事件。比如你如果綁定了afterChange事件,如果觸發(fā)了回調(diào),那么一定是值被改變了,而不是即便試圖更改屬性值卻在beforeChange中被阻止了。

validator和setter的校驗(yàn)強(qiáng)度是你來決定的,如果你的validator的校驗(yàn)邏輯很嚴(yán)格,就不用再在setter中添加嚴(yán)格的校驗(yàn),甚至不需要setter,反之亦然,setter校驗(yàn)很嚴(yán)格的話也可以缺省validator。比如,下面兩句代碼,你可以任選其一:

validator: Y.Lang.isBoolean,   // to make the attribute accepts strictly a Boolean
setter: Boolean, // to make the attribute accept any value and have Boolean

Setter也可以作為校驗(yàn)器來使用。如果輸入的值不能轉(zhuǎn)換成attribute可接受的值,setter就會(huì)返回Y.Attribute.INVALID_VALUE。這種情況下,attribute不會(huì)發(fā)生改變。

當(dāng)我定義成員的時(shí)候,通常會(huì)指定這個(gè)常量,并放在模塊的頂部(和CBX, BBX這些縮寫聲明一起),例如:

var VALUE = ‘value’,
    VALID_CODES = ‘validCodes’;

這樣做的原因是,在一個(gè)模塊內(nèi)可能會(huì)多次用到這個(gè)值,使用常量更加方便。但是,請千萬別在屬性聲明中使用這些常量。

ATTRS: {
    // *** Don’t do this *** //
    VALUE: {
        value: 0,
        validator: Lang.isNumber
    }
}

這樣書寫會(huì)生成一個(gè)名為VALUE而不是value的屬性成員,同時(shí)記住,不要覆蓋基類中的屬性成員,Widget中已經(jīng)有許多屬性成員(見表格),如boundingBox、visible、disabled、height、width等,你也可以修改他們,Y.Base.create()會(huì)將父類和基類(Base)中的屬性成員合并,所以要重載已有的屬性成員,你只要在派生類中重復(fù)定義即可。

當(dāng)你要定義的屬性成員是數(shù)組或者對象的時(shí)候要尤為小心,對象(數(shù)組)是一個(gè)引用值,如果初始化的屬性中含有object,他們(所有實(shí)例的這個(gè)成員)指向的會(huì)是同一個(gè)object。當(dāng)你更改這個(gè)object或者刪除的時(shí)候,所有的實(shí)例也都跟著改變(prototye永遠(yuǎn)指向父類的prototye),所以,Base提供了克隆的機(jī)制,在你傳入object屬性成員的時(shí)候克隆一份,這會(huì)避免引用重復(fù)的問題,其他objects的初始化,請使用valueFn參數(shù),或者直接在類的構(gòu)造函數(shù)(initialize)中構(gòu)建他們。

出處:Taobao.com UED Team
責(zé)任編輯:bluehearts

上一頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [2] 下一頁 使用YUI 3開發(fā)Web應(yīng)用的訣竅 [4]

◎進(jìn)入論壇網(wǎng)頁制作、WEB標(biāo)準(zhǔn)化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章
構(gòu)建成功web應(yīng)用的十項(xiàng)黃金法則
作者文章
什么是Node?
JS語法檢查插件 jsLint for Vim
一場關(guān)于YUI3/jQuery的精彩辯論
YUI3設(shè)計(jì)中的激進(jìn)和妥協(xié)
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計(jì)比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗(yàn) UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點(diǎn)最新 站點(diǎn)最新列表
周大!熬•自然”設(shè)計(jì)大賽開啟
國際體驗(yàn)設(shè)計(jì)大會(huì)7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計(jì)算如何讓安全問題可控
云計(jì)算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機(jī)會(huì)
阿里行云
云手機(jī)年終巨獻(xiàn),送禮標(biāo)配299起
阿里巴巴CTO王堅(jiān)的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機(jī)主題設(shè)計(jì)大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺(tái)歷
Ps簡單繪制一個(gè)可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機(jī)制之一:普通流
25個(gè)最佳最閃亮的Eclipse開發(fā)項(xiàng)目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:3/91個(gè)記錄/頁 轉(zhuǎn)到 頁 共9個(gè)記錄

藍(lán)色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨(dú)家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點(diǎn)的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點(diǎn)的水印,亦不能抹去我站點(diǎn)水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計(jì)作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會(huì)員,你可以注冊 為本站會(huì)員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯(cuò)誤,請用報(bào)告錯(cuò)誤,以利文檔及時(shí)修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報(bào)告管理員,以利管理員及時(shí)刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項(xiàng)有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報(bào)告錯(cuò)誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計(jì)之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計(jì)》
犀利開發(fā)—jQuery內(nèi)核詳解與實(shí)踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2