Javascript前端UI框架Kit使用指南之kitjs的對(duì)話框組件
Kit作為一個(gè)UI庫(kù),我并沒(méi)有打算讓大家都來(lái)學(xué)習(xí)我的Kit的Core,背熟我的API,這種跟風(fēng)的學(xué)習(xí)方式一點(diǎn)意義都沒(méi)有,今天jQuery熱,大家都是學(xué)jQ,明天SeaJs火了,大家都去炒SeaJs,所以我在KitJs里面,專門為jQ的用戶準(zhǔn)備了一個(gè)語(yǔ)法糖(Suger.js),完全模擬jQ的API,除了實(shí)現(xiàn),接口都一樣,也方便大家直接拿來(lái)主義的改造Kit的組件。當(dāng)然,作為一個(gè)純技術(shù)Fan來(lái)說(shuō),深入理解一門技術(shù)是如何實(shí)現(xiàn)的,遠(yuǎn)比拿來(lái)主義更有趣的多^_^。當(dāng)然了,如果你出于KPI考慮,或者老板的老板的項(xiàng)目獎(jiǎng)金,直接拿來(lái)主義抄襲Kit的組件代碼,完成你的KPI,我也不介意這樣的行為,只要您喝水不忘挖井人,在和同事吹水的時(shí)候,也能宣傳一個(gè)KitJs,我就很感激您了。同時(shí),Kit也是一個(gè)很年輕的庫(kù),出于不斷的發(fā)展之中,有一些BUG以及瀏覽器兼容問(wèn)題,在所難免,我一個(gè)人也精力有限,在這個(gè)前端戰(zhàn)火紛飛的年代,歡迎更多志同道合的基友一起把他搞大,共同進(jìn)步。
同時(shí),今天發(fā)布了一個(gè)kitjs的對(duì)話框組件,demo地址為http://xueduany.github.com/KitJs/KitJs/demo/Dialog/demo.html
(一)Kit目錄格式
言歸正傳,在KitJs里,kit.js是作為核心的Core文件的存在,他包含了一些最常用的Dom以及Object,繼承的操作,同級(jí)目錄下按照功能的劃分?jǐn)U展了一批string.js,math.js等等都是為了實(shí)現(xiàn)特定方向功能的擴(kuò)展。每一個(gè)獨(dú)立的js文件都包含一個(gè)Class的構(gòu)造器,以及一個(gè)全局對(duì)象的實(shí)例,
以kit.js為例,包含了$Kit類,以及$Kit類的實(shí)例$kit(以$開(kāi)頭是為了避免與常用的變量沖突),
其他各類,都以Link的方式,掛在$Kit,以及$kit實(shí)例實(shí)例上,如math.js,包含了$Kit.Math類,以及$kit.math實(shí)例,這樣保證全局范圍里只有$Kit和$kit兩個(gè)污染。同時(shí),在kit.js,我們定義了一個(gè)命名空間叫做$kit.ui,在物理目錄下,以kit.js同級(jí)的Widget目錄,一字排開(kāi),多個(gè)首字母大寫的目錄
widget目錄下所有目錄都是kitjs的組件目錄,每個(gè)獨(dú)立js文件只包含一個(gè)獨(dú)立組件的class構(gòu)造器(非實(shí)例),同時(shí)可以兼容commonJs的module模式(可以符合CommonJs的Modules/1.1 規(guī)范,以及AMD方式改造,具體改造方式后面會(huì)以后會(huì)詳細(xì)提及)
(二)Kit組件默認(rèn)代碼模板,注釋符合jsdoc規(guī)范
我們以對(duì)話框組件舉例,每個(gè)組件都類似如下
首先是jsdoc的注釋,@class申明是一個(gè)什么類,@require xxx.js,申明依賴哪些組件
(三)構(gòu)造器以及初始化方法
每個(gè)類都是標(biāo)準(zhǔn)的function(config){}的方式定義個(gè)構(gòu)造器,這里需要注意的是,每個(gè)kitjs組件的構(gòu)造器默認(rèn)預(yù)留一個(gè)config參數(shù),作為個(gè)性化配置的輸入,
同時(shí)在類的構(gòu)造器,有個(gè)一個(gè)靜態(tài)成員,defaultConfig對(duì)象,用來(lái)存放kitjs組件的默認(rèn)配置
在使用kitjs的組件,首先是需要通過(guò)new Instance的方式new $kit.ui.Dialog.YesOrNo,初始化一個(gè)新的實(shí)例對(duì)象出來(lái),這是僅僅是初始化了一個(gè)js的組件對(duì)象,還沒(méi)有HTML,需要執(zhí)行init方法,創(chuàng)建HTML,加入doc中,等于給靈魂澆上血肉^_^。
可能有同學(xué)會(huì)問(wèn),為什么不把init方法直接放在構(gòu)造器里面,而要另外單獨(dú)放出來(lái)?
1是因?yàn)樵诶^承時(shí)候需要實(shí)例化父類,當(dāng)子類繼承于父類的時(shí)候,會(huì)設(shè)置子類的prototype對(duì)象為父類的new Instance新的實(shí)例對(duì)象,如果在構(gòu)造器里面放了init的初始化方法,會(huì)導(dǎo)致父類的HTML被直接執(zhí)行,生成垃圾代碼,
2是因?yàn)榭紤]懶加載的情況,需要HTML代碼在恰當(dāng)?shù)臅r(shí)間執(zhí)行,而不是一開(kāi)始初始化時(shí)立即執(zhí)行
所以使用kitjs組件的默認(rèn)方式是
實(shí)例化之后,執(zhí)行init方法(init方法會(huì)返回當(dāng)前組件對(duì)象,有return代碼7)
上圖可以發(fā)現(xiàn),在dialog中所有API method都是掛在prototype上,通過(guò)原型擴(kuò)展的方式實(shí)現(xiàn)繼承以及傳遞給實(shí)例對(duì)象
觀察$kit.ui.Dialog.YesOrNo組件的構(gòu)造器代碼,
(四)KitJs的繼承
他通過(guò)$kit.inherit方法申明了與$kit.ui.Dialog對(duì)象的繼承關(guān)系,這里會(huì)有同學(xué)要問(wèn),為什么要在構(gòu)造器里面繼承,而不是直接寫在外面?
原因是:
1.kitjs是一個(gè)基于prototype維護(hù)繼承關(guān)系的
2.要使用kitjs的組件,必須要實(shí)例化該組件對(duì)象,每個(gè)組件都是通過(guò)new Instance的方式,通過(guò)構(gòu)造器創(chuàng)建的
所以我把繼承關(guān)系的執(zhí)行放在代碼的構(gòu)造器中,這樣在實(shí)例化一個(gè)新的組件時(shí),就會(huì)順著當(dāng)前組件的構(gòu)造器的繼承方法,逐級(jí)去繼承到他父類的成員以及方法。
當(dāng)子類需要修改父類的方法時(shí),只需要在子類的prototype里從定義一個(gè)同名的method即可覆蓋父類的繼承方法。
在命名上,kitjs遵循,子類延續(xù)父類的類名作為Namespace,一直鏈下去,如上圖的$kit.ui.Dialog,$kit.ui.Dialog.YesOrNo
kitjs的繼承實(shí)現(xiàn)也很簡(jiǎn)單
實(shí)例化一個(gè)父類對(duì)象,將父類的實(shí)例所有成員copy到子類的原型上,然后重置子類的原型的構(gòu)造器為子類構(gòu)造器,再給子類構(gòu)造器掛一個(gè)link,指向父類,通過(guò)$kit.inherit方法,在子類$kit.ui.Dialog.YesOrNo實(shí)例化的過(guò)程中,就可以繼承父類$kit.ui.Dialog的所有子類不存在的成員,實(shí)現(xiàn)類似靜態(tài)語(yǔ)言的繼承
(五)config參數(shù),HTML與Css的耦合拆解/換膚?
kit的組件構(gòu)造器習(xí)慣傳入一個(gè) Map類型的參數(shù),從來(lái)個(gè)性化組件,在kit組件初始化的時(shí)候,會(huì)自動(dòng)用用戶提交的config參數(shù)覆蓋默認(rèn)的defaultConfig后開(kāi)始初始化。
對(duì)于任何一個(gè)組件來(lái)說(shuō),擺脫不了是HTML結(jié)構(gòu)的變化,以及Css樣式的改變
kit把這種耦合分解在config的參數(shù)配置里面,
首先是使用HTML模板技術(shù),kit提倡使用$kit.newHTML方法直接根絕HTML String,生成HTML DOM插入文檔流,
所以我們抽取組件的大概HTML內(nèi)容,封裝成HTML String模板,存放在組件的defaultConfig里面,如果用戶需要修改HTML模板,自己在初始化的時(shí)候使用自定義的config,覆蓋默認(rèn)的defaultConfig里面的模板字段即可,
在HTML模板與Css的耦合分解上,kit用了一個(gè)技巧就是把className用js模板的方式,分解開(kāi)來(lái)
通過(guò)在init方法中的$kit.tpl 將config 中的html以${xxx}的方式對(duì)應(yīng)config中的xxx做替換
同時(shí)所有的樣式都在css里面設(shè)置,
如果有多套皮膚需要切換,可以選擇在初始化時(shí)候,通過(guò)config指定${cls}對(duì)應(yīng)的實(shí)際className來(lái)達(dá)到修改模板的className,來(lái)達(dá)到換膚的效果。
(六)小結(jié)
基本上,透過(guò)對(duì)$kit.ui.Dialog.YesOrNo組件的代碼分析,我們對(duì)kitjs的組件實(shí)現(xiàn)結(jié)構(gòu)有了一個(gè)大概的了解。其實(shí)設(shè)計(jì)一個(gè)頁(yè)面組件并不難,但是設(shè)計(jì)一個(gè)能適應(yīng)各種要求,在各種場(chǎng)合下,可以很快速的變形,并適應(yīng)開(kāi)發(fā),是一個(gè)很難的要求。kit通過(guò)對(duì)HTML模板以及Css的拆分,自定義config參數(shù)與defaultConfig的配合,子類通過(guò)繼承的方式獲得父類的屬性以及方法,同時(shí)根據(jù)不同的業(yè)務(wù)需要重構(gòu)相關(guān)代碼,基本上可以靈活的滿足各種層次,各種環(huán)境下的業(yè)務(wù)UI組件需求。
KitJs包括了基本庫(kù)和UI庫(kù),
基本庫(kù): 選擇器功能,dom操作功能,動(dòng)畫功能,增強(qiáng)dom事件,增加hashtree數(shù)據(jù)結(jié)構(gòu),io功能,本地存儲(chǔ)功能,多線程,range等等
還有一個(gè)模擬jquery操作格式的suger.js
UI庫(kù)包括了:增強(qiáng)的form元素,彈出層,媒體播放器,驗(yàn)證框架,瀑布流,聯(lián)動(dòng),幻燈片,日歷,上傳組件,模板引擎等等
- JavaScript框架編程
- 10個(gè)新的最有前途的JavaScript框架
- JavaScript 異步調(diào)用框架 (Part 6 - 實(shí)例 & 模式)
- myEvent.js javascript跨瀏覽器事件框架
- 詳細(xì)介紹8款超實(shí)用JavaScript框架
- JavaScript框架(iframe)操作總結(jié)
- Javascript MVC框架Backbone.js詳解
- Javascript前端UI框架Kit使用指南之Kitjs簡(jiǎn)介
- Javascript前端UI框架Kit使用指南之kitjs事件管理
- javascript框架設(shè)計(jì)讀書筆記之模塊加載系統(tǒng)
- JavaScript跨平臺(tái)的開(kāi)源框架NativeScript
相關(guān)文章
form表單中去掉默認(rèn)的enter鍵提交并綁定js方法實(shí)現(xiàn)代碼
form表單中默認(rèn)的enter提交是不是讓你已經(jīng)很耐煩了吧,本文主要講解一下如何去掉默認(rèn)的enter鍵提交同時(shí)綁定js方法,感興趣的朋友可以參考下哈2013-04-04淺談?dòng)肳ebpack路徑壓縮圖片上傳尺寸獲取的問(wèn)題
下面小編就為大家分享一篇淺談?dòng)肳ebpack路徑壓縮圖片上傳尺寸獲取的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02使用?Angular?服務(wù)器端渲染?Transfer?State?Service
這篇文章主要介紹了使用?Angular?服務(wù)器端渲染?Transfer?State?Service,假設(shè)我們使用?Angular?Universal?開(kāi)發(fā)一個(gè)服務(wù)器端渲染的?Angular?應(yīng)用,這個(gè)應(yīng)用會(huì)消費(fèi)一個(gè)第三方的?Restful?API2022-06-06JavaScript中的索引數(shù)組、關(guān)聯(lián)數(shù)組和靜態(tài)數(shù)組、動(dòng)態(tài)數(shù)組講解
這篇文章主要介紹了JavaScript中的索引數(shù)組、關(guān)聯(lián)數(shù)組和靜態(tài)數(shù)組、動(dòng)態(tài)數(shù)組講解,本文介紹了從數(shù)組的下標(biāo)分為索引數(shù)組、關(guān)聯(lián)數(shù)組、從對(duì)數(shù)據(jù)的存儲(chǔ)分為靜態(tài)數(shù)組、動(dòng)態(tài)數(shù)組,并給出了示例,需要的朋友可以參考下2014-11-11微信小程序?qū)崿F(xiàn)多選框功能的實(shí)例代碼
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)多選框功能及效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06JS正則表達(dá)式驗(yàn)證賬號(hào)、手機(jī)號(hào)、電話和郵箱是否合法
這篇文章主要介紹了JS正則表達(dá)式驗(yàn)證賬號(hào)、手機(jī)號(hào)、電話和郵箱是否合法,需要的朋友可以參考下2017-03-03JavaScript設(shè)計(jì)模式之職責(zé)鏈模式詳解
職責(zé)鏈模式的定義是:使多個(gè)對(duì)象都有機(jī)會(huì)處理請(qǐng)求,從而避免請(qǐng)求的發(fā)送者和接收者之間的耦合關(guān)系,將這些對(duì)象連成一條鏈,并沿著這條鏈傳遞該請(qǐng)求,直到有一個(gè)對(duì)象處理它為止2022-08-08JavaScript實(shí)現(xiàn)類似淘寶的購(gòu)物車效果
這篇文章主要介紹了JavaScript實(shí)現(xiàn)購(gòu)物車特效的相關(guān)資料,文中通過(guò)示例代碼詳細(xì)介紹了,利用Javascript如何實(shí)現(xiàn)類似淘寶購(gòu)物車中商品的單選、全選、刪除、修改等功能,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-03-03