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

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

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

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

與其他模塊的通信

在實現(xiàn)一個模塊之后,它會和其他模塊進行交互。傳統(tǒng)的方法是緊耦合(通過Nicholas Zakas的視頻中我們可以了解什么是緊耦合什么是松耦合),也就是通過方法調(diào)用和屬性賦值來將這些模塊緊密聯(lián)系在一起,在這兒就不贅述了。下面我們介紹另一種方法——自定義事件,Y.Base里面包含了你所需要的全部方法。

首先,在initializer中,你要發(fā)布這個自定義事件,讓大家都知道它:

initializer: function (cfg) {
    this.publish(‘eventName’, { /*… options … */});
},

需要注意的是,事件名稱最好是一個常見單詞,因為在后面你會經(jīng)常使用它,常見單詞可以避免出現(xiàn)拼寫錯誤。然后,假設你擁有一個對象,例如:

var myWidget = new Y.MyWidget({ /* .. attributes … */ });

此時,你可以為它綁定事件:

myWidget.after(‘eventName’, this._eventNameListener, this);

然而,這樣做雖然不像直接的方法調(diào)用那樣聯(lián)系緊密,但是由于必須有一個myWidget的實例,所以其實質(zhì)還是緊耦合。也就是說,在兩個模塊的通信中,一個模塊必須知道另一個的細節(jié),或者存在一個監(jiān)視模塊為它們建立連接。在這個過程中,有兩個配置項是非常重要的,broadcast和emitFacade。

第一個,broadcast,可以讓你在其他的模塊中為這個事件設置監(jiān)聽器。broadcast默認值為0,此時只能用前面所示的那個方法。如果希望事件可以在任何地方被監(jiān)聽,你需要改變broadcast的值。如果只是在沙箱內(nèi),broadcast值為1,如果需要在各個沙箱間,則broadcast值為2。一個沙箱如下所示:

YUI().use( ‘module1′, …, ‘moduleN’, function (Y) {
    // this is your sandbox
});

在頁面中可以有多個這樣的沙箱:

YUI().use( ‘module1′, …, ‘moduleN’, function (Y) {
    // this is your sandbox
});
YUI().use( ‘moduleX-1′, …, ‘moduleX-N’, function (Z) {
    // this is another sandbox
});

如果你設置broadcast值為2,你就可以在沙箱2中監(jiān)聽在沙箱1中發(fā)布的事件,具體細節(jié)請看Event user guide。我們繼續(xù)討論簡單沙箱的情況。

要在一個沙箱內(nèi)監(jiān)聽另一個模塊中發(fā)布的事件,必須知道的是這個模塊的靜態(tài)屬性NAME的值和事件名稱;叵胂,Y.Base.create方法所帶的第一個參數(shù)的值,就是NAME屬性的值。因此,如果你創(chuàng)建了這樣一個模塊:

Y.MyWidget = Y.Base.create(
    ‘xxxx’,
    Y.Widget,
    // … and so on

然后在initializer發(fā)布了一個’help’事件:

initializer: function (config) {
    this.publish(‘help’, {
        broadcast: 1,
        emitFacade: true
    });
},

那么,要在其他模塊的沙箱內(nèi)監(jiān)聽這個事件,就可以這樣做:

Y.after(‘xxxx:help’, function (ev) { … }, this);

在這里調(diào)用了Y.after,而不是myWidget.after,所以我不再需要一個實例才能觸發(fā)這個事件。你也可以用同樣的方法來監(jiān)聽DOM事件或者其他的自定義事件,比如’valueChange’等,不同的僅僅是引號前面的前綴。你也可以使用別的東西作為前綴,Y.base會接受這個值,但是通常情況下,Y.base提供的默認值已經(jīng)足夠了。你還需要設置emitFacade值,因為需要一個對象來觸發(fā)事件,從而為ev.target提供門面值(facade value)。也許你會想,如果監(jiān)聽器所在的模塊獲得了注冊事件模塊的對象,那不是重新成為緊耦合了么。但事實并非如此,只要你在監(jiān)聽器模塊中不保留這個對象,耦合就不復存在。此外,我們還有更好的辦法。

出處:Taobao.com UED Team
責任編輯:bluehearts

上一頁 使用YUI 3開發(fā)Web應用的訣竅 [6] 下一頁 使用YUI 3開發(fā)Web應用的訣竅 [8]

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

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

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

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

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

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

雜⑦雜⑧ Gold NORMANA V2