JavaScrip面向?qū)ο罄斫?/h1>

JavaScrip面向?qū)ο罄斫?

JavaScrip的對象簡單來說一組無序的值,其中的屬性或方法都有一個(gè)名字动壤,面向?qū)ο蟾欣谄髽I(yè)對于網(wǎng)頁的開發(fā)乞封。

有所了解后,我們可以做一個(gè)例子來了解(表單生成器)

1.首先我們需要定義存儲結(jié)構(gòu)并將其轉(zhuǎn)化成對象

var elements = [? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? {tag:'input', text:'姓  名:', attr: {type:'text', name:'user'}? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? {tag:'input', text:'性  別:', attr: {type:'radio', name:'gender'}, option: {m:'男', w:'女'}},? {tag:'input', text:'愛  好:', attr: {type:'checkbox', name:'hobby[]'}, option:? {swimming:'游泳', reading:'讀書', running:'跑步'}},{tag:'select', text:'住  址:', attr:? {name:'area'}, option: {'':'--請選擇--', bj:'北京', sh:'上海', sz:'深圳'}},? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? {tag:'textarea', text:'自我介紹:', attr: {name:'introduce', cols:'50', rows:'5'}},? ? ? ? ? ? ? ? ? ? ? {tag:'input', attr: {type:'submit', value:'提交'}}? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?];

2.然后封裝生成器

(function(window) {? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? var FormBuilder =function(data) {? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? this.data = data;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? };? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? window.FormBuilder =FormBuilder;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?})(window);

上述代碼最外層是一個(gè)自調(diào)用的匿名函數(shù)习瑰,在調(diào)用時(shí)傳入的window 對象用于控制FormBuilder庫的作用范圍,通過“?window.FormBuilder =FormBuilder;”將FormBuilder作為傳入對象的屬性秽荤。由于window對象是全局的甜奄,因此當(dāng)上述代碼執(zhí)行后,就可以直接使用FormBuilder窃款。另一方面课兄,在匿名函數(shù)中定義的變量、函數(shù)晨继,都不會污染全局作用域烟阐,體現(xiàn)了面向?qū)ο蟮姆庋b性。

接下來創(chuàng)建form.html踱稍,用于調(diào)用FromBuilder生成表單

<script src="FormBuilder.js">

? ? // 這里并不是使用JSON語法保存數(shù)據(jù)(鍵和值都加雙引號,且對特殊字符轉(zhuǎn)義)? ? ? ? ?

{tag:'input', text:'姓  名:', attr: {type:'text', name:'user'}? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? {tag:'input', text:'性  別:', attr: {type:'radio', name:'gender'}, option: {m:'男', w:'女'}},? {tag:'input', text:'愛  好:', attr: {type:'checkbox', name:'hobby[]'}, option:? {swimming:'游泳', reading:'讀書', running:'跑步'}},{tag:'select', text:'住  址:', attr:? {name:'area'}, option: {'':'--請選擇--', bj:'北京', sh:'上海', sz:'深圳'}},? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? {tag:'textarea', text:'自我介紹:', attr: {name:'introduce', cols:'50', rows:'5'}},? ? ? ? ? ? ? ? ? ? ? {tag:'input', attr: {type:'submit', value:'提交'}}? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?];

?document.getElementById('form').innerHTML =new FormBuilder(elements).create();

</script>

通過new FormBuilder()實(shí)例化了表單生成器對象悠抹,將elements數(shù)組通過參數(shù)傳入珠月,然后調(diào)用了create()方法,該方法用于返回HTML生成結(jié)果楔敌,將在后面的步驟中實(shí)現(xiàn)啤挎。

3.實(shí)現(xiàn)表單自動生成

編寫create()方法

FormBuilder.prototype.create =function() {

?var html ='';

?for (var kin this.data) {

? ? ?var item = {tag:'', text:'', attr: {}, option:null};

? ? ?for (var nin this.data[k]) {

? ? ? ? ? ? item[n] =this.data[k][n];

? ? }

? ? ? ? html += builder.toHTML(item);

? ? }

? ? return '<table>' + html +'</table>';

};

編寫buider對象

var builder = {

toHTML:function(obj) {

var html =this.item[obj.tag](this.attr(obj.attr), obj.option);

? ? return '<tr><th>' + obj.text +'</th><td>' + html +'</td></tr>';

? },

? attr:function(attr) {

? ? var html ='';

? ? for(var kin attr) {

? ? ? ?html += k +'="' + attr[k] +'" ';

? ? ?}

? ? ?return html;

? },

(item對象)

}

在上述代碼中,“this.item[obj.tag]()" 用于根據(jù)obj.tag的值來調(diào)用item對象中的萬法卵凑。例如庆聘,當(dāng)obj.tag的值為input時(shí),就表示調(diào)用builder item.input()方法勺卢。item對象是builder對象的一個(gè)屬性伙判,該對象內(nèi)包含了input()、select()和 textarea()3個(gè)方法黑忱,分別用于生成<input>宴抚、<select> 和<textarea>表單項(xiàng)。

編寫item對象

item: {

input:function(attr, option) {

var html ='';

? ? if (option ===null) {

html +='<input ' + attr +'>';

? ? }else {

for (var kin option) {

html +='<label><input ' + attr +'value="'? + k +'"' +'>' + option[k] +'</label>';

? ? ? }

}

return html;

? },

? select:function(attr, option) {

var html ='';

? ? for (var kin option) {

html +='<option value="' + k +'">' + option[k] +'</option>';

? ? }

return '<select ' + attr +'>' + html +'</select>';

? },

? textarea:function(attr) {

return '<textarea ' + attr +'></textarea>';

? }

加上樣式對吼呈現(xiàn)的效果如下

總結(jié)來說JavaScript的面向?qū)ο蠛推渌Z言也差不多甫煞,對對象的而操作無非就是創(chuàng)建對象創(chuàng)建的方式用很多菇曲,自己也了解是很清楚,很多還得通過大牛講解抚吠,然后就是對對象的屬性進(jìn)行訪問賦值刪除常潮,也可以繼承。這些利于封裝框架楷力,利于數(shù)據(jù)處理喊式,邏輯清晰孵户,不會容易出現(xiàn)混亂。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者

  • 序言:七十年代末垃帅,一起剝皮案震驚了整個(gè)濱河市延届,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌贸诚,老刑警劉巖方庭,帶你破解...
    沈念sama閱讀 211,948評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異酱固,居然都是意外死亡械念,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,371評論 3 385
  • 文/潘曉璐 我一進(jìn)店門运悲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來龄减,“玉大人,你說我怎么就攤上這事班眯∠M#” “怎么了?”我有些...
    開封第一講書人閱讀 157,490評論 0 348
  • 文/不壞的土叔 我叫張陵署隘,是天一觀的道長宠能。 經(jīng)常有香客問我,道長磁餐,這世上最難降的妖魔是什么违崇? 我笑而不...
    開封第一講書人閱讀 56,521評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮诊霹,結(jié)果婚禮上羞延,老公的妹妹穿的比我還像新娘。我一直安慰自己脾还,他們只是感情好伴箩,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,627評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著鄙漏,像睡著了一般赛蔫。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上泥张,一...
    開封第一講書人閱讀 49,842評論 1 290
  • 那天呵恢,我揣著相機(jī)與錄音,去河邊找鬼媚创。 笑死渗钉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鳄橘,決...
    沈念sama閱讀 38,997評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼声离,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了瘫怜?” 一聲冷哼從身側(cè)響起术徊,我...
    開封第一講書人閱讀 37,741評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎鲸湃,沒想到半個(gè)月后赠涮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,203評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡暗挑,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,534評論 2 327
  • 正文 我和宋清朗相戀三年笋除,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片炸裆。...
    茶點(diǎn)故事閱讀 38,673評論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡垃它,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出烹看,到底是詐尸還是另有隱情国拇,我是刑警寧澤,帶...
    沈念sama閱讀 34,339評論 4 330
  • 正文 年R本政府宣布惯殊,位于F島的核電站酱吝,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏靠胜。R本人自食惡果不足惜掉瞳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,955評論 3 313
  • 文/蒙蒙 一毕源、第九天 我趴在偏房一處隱蔽的房頂上張望浪漠。 院中可真熱鬧,春花似錦霎褐、人聲如沸址愿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,770評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽响谓。三九已至,卻和暖如春省艳,著一層夾襖步出監(jiān)牢的瞬間娘纷,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,000評論 1 266
  • 我被黑心中介騙來泰國打工跋炕, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留赖晶,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,394評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像遏插,于是被迫代替她去往敵國和親捂贿。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,562評論 2 349

推薦閱讀更多精彩內(nèi)容