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

您的位置: 首頁 > 技術文檔 > 網頁制作 > 使用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]

在發(fā)布事件時,我們可以添加所有在事件對象中監(jiān)聽器所需要的信息,例如:

this.fire(‘help’, {helpTopic: ‘Event Broadcasting’});

fire()方法的兩個參數分別為發(fā)布事件的名稱(也就是Y.Base為它增加前綴的類的名稱)和包含一些特性的對象(這些特性需要復制給事件對象)。這樣監(jiān)聽器就不需要為了獲取一些信息而遍歷注冊事件模塊,從而達到了松耦合的目的。監(jiān)聽器通過“事件廣播”知道有這樣的一些模塊,甚至可能有很多這樣的模塊會響應help事件,但并不需要關注是哪一個模塊正在響應它。這種方法也簡化了日后新模塊的添加。

事件和默認行為

要改變一個類的行為,通常的辦法是建立一個子類,然后重寫它的方法。YUI也可以完成這些工作。你可以用Y.Base.create來創(chuàng)建一個基類Y.Widget,然后用Y.Base.create來創(chuàng)建一個新的類來作為基類的擴展,并給予其一些特殊的行為。例如,先創(chuàng)建基類:

Y.MySimpleWidget = Y.Base.create(
    ‘simpleWidget’,
    Y.Widget,
    [],
    {
        // instance members here, amongst them:
        renderUI: function () {
            this.get(CBX).append(Y.Node.create(‘ … whatever goes into the widget … ‘ ));
        }
    },
    {
        ATTRS: {
            // configuration attributes
        }
        // other static members
    }
);

然后創(chuàng)建子類:

Y.MyFancyWidget = Y.Base.create(
    ‘fancyWidget’,
    Y.MySimpleWidget,
    [],
    {
        renderUI: function () {
            Y.MyFancyWidget.superclass.renderUI.apply(this, arguments);
            this.get(CBX).append(Y.Node.create(‘ … add some bells and whistles … ‘ ));
    }
    // Presumably the fancy version does not need any further static members so I skip the last argument
);

我們可以看到,MyFancyWidget通過添加一些細節(jié)改進了MySimpleWidget。但是這在某些情況下會有些問題,所以你需要設計一個更靈活,更容易改變的基類。自定義事件會對你有所幫助。

假設有個排序類,擁有key和direction兩個參數,聲明如下:

sort: function (key, direction) {
     // sorting happens here
},

如果這個函數的行為在某些情況下需要更改,您可以這么做,在initializer方法中添加自定義事件:

initializer: function (config) {
    // amongst many other things:
    this.publish(SORT, {defaultFn: this._defSortFn});
},

若SORT是一個具有排序功能的實例,你可以這樣聲明它的sort函數:

sort: function(key, direction) {
    this.fire(SORT, {key:key, direction:direction});
},

這樣子,排序函數就轉換為一個具有相同參數的事件觸發(fā)函數。這樣只是提供了一個轉換接口,你仍然需要通過原始的排序函數來設計一個類:

_defSortFn: function (ev) {
    var key = ev.key, direction = ev.direction;
    // same code as the original sort function
},

這個_defSortFn類的函數體與原始的方法一模一樣,達到相同的排序目的。但是你可以從事件對象中知道key和direction參數,只要一段簡單的代碼段就可以設置一個監(jiān)聽器,并且改變排序方法。

myObjectThatSorts.on(‘sort’, function (ev) {
    var key = ev.key, direction = ev.direction;
    ev.preventDefault();
    // now do your own sort
});

通過preventDefault我讓myObjectThatSorts不再執(zhí)行_defSortFn中的排序方法,從而可以根據我需要的結果做任何事,無論原來的排序是什么樣。我甚至不用關心它是否停止,只要監(jiān)聽after事件來翻轉UI上用來顯示排序方向的箭頭。

我也可以改變事件對象。當事件觸發(fā)時,我們得到的是根據事件對象復制的一個對象,它從before監(jiān)聽器開始傳播,通過默認的函數,到達after監(jiān)聽器,然后被丟棄。你可以在過程中改變它的一些屬性的值。當然,在默認方法執(zhí)行后再做任何改變是沒有影響的,在執(zhí)行之前改變事件對象才能對方法有所影響。例如。

myObjectThatSorts.on(‘sort’, function (ev) {
    ev.direction = (ev.direction===’desc’?'asc’:'desc’);
});

這樣將得到倒置的排序結果。

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

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

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

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

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

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

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

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

雜⑦雜⑧ Gold NORMANA V2