精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何開發一個完整的JavaScript組件

開發 前端
作為一名開發者,大家應該都知道在瀏覽器中存在一些內置的控件:Alert,Confirm等,但是這些控件通常根據瀏覽器產商的不同而形態各異,視覺效果往往達不到UI設計師的要求。更重要的是,這類內置控件的風格很難與形形色色的各種風格迥異的互聯網產品的設計風格統一。因此,優秀的前端開發者們各自開發自己的個性化控件來替代瀏覽器內置的這些控件。

作為一名開發者,大家應該都知道在瀏覽器中存在一些內置的控件:Alert,Confirm等,但是這些控件通常根據瀏覽器產商的不同而形態各異,視覺效果往往達不到UI設計師的要求。更重要的是,這類內置控件的風格很難與形形色色的各種風格迥異的互聯網產品的設計風格統一。因此,優秀的前端開發者們各自開發自己的個性化控件來替代瀏覽器內置的這些控件。當然,這類組件在網絡上已經有不計其數相當優秀的,寫這篇文章的目的不是為了說明我開發的這個組件有多優秀,也不是為了炫耀什么,只是希望通過這種方式,與更多的開發者互相交流,互相學習,共同進步。好,廢話不多說,言歸正傳。

功能介紹

  • 取代瀏覽器自帶的Alert、Confirm控件
  • 自定義界面樣式
  • 使用方式與內置控件基本保持一致

效果預覽

1、Alert控件

 

 

2、Confirm控件

如何開發一個完整的JavaScript組件

 

3、完整代碼,在線預覽(見底部,提供壓縮包下載)

#p#

開發過程

1. 組件結構設計

首先,我們來看下內置組件的基本使用方法:

  1. alert("內置Alert控件"); 
  2. if (confirm("關閉內置Confirm控件?")) { 
  3.     alert("True"); 
  4. else { 
  5.     alert("False"); 

為了保證我們的組件使用方式和內置控件保持一致,所以我們必須考慮覆蓋內置控件。考慮到組件開發的風格統一,易用,易維護,以及面向對象等特性,我計劃將自定義的alert和confirm方法作為一個類(Winpop)的實例方法,最后用實例方法去覆蓋系統內置控件的方法。為了達到目的,我的基本做法如下:

  1. var obj = new Winpop(); // 創建一個Winpop的實例對象 
  2. // 覆蓋alert控件 
  3. window.alert = function(str) { 
  4.     obj.alert.call(obj, str); 
  5. }; 
  6. // 覆蓋confirm控件 
  7. window.confirm = function(str, cb) { 
  8.     obj.confirm.call(obj, str, cb); 
  9. }; 

需要注意的是,由于瀏覽器內置的控件可以阻止瀏覽器的其他行為,而我們自定義的組件并不能具備這種能力,為了盡可能的做到統一,正如預覽圖上看到的,我們在彈出自定義組件的時候使用了一個全屏半透明遮罩層。也正是由于上述原因,confirm組件的使用方式也做了一些細微的調整,由內置返回布爾值的方式,改為使用回調函數的方式,以確保可以正確的添加“確定”和“取消”的邏輯。因此,自定義組件的使用方式就變成了下面這種形式:

  1. alert("自定義Alert組件"); 
  2. confirm("關閉自定義Confirm組件?", function(flag){ 
  3.     if (flag) { 
  4.         alert("True"); 
  5.     } else { 
  6.         alert("False"); 
  7.     } 
  8. }); 

2. 組件代碼設計

在正式介紹Winpop組件的代碼之前,我們先來看一下一個Javascript組件的基本結構:

  1. function(window, undefined) { 
  2.     function JsClassName(cfg) { 
  3.         var config = cfg || {}; 
  4.         this.get = function(n) { 
  5.             return config[n]; 
  6.         } 
  7.         this.set = function(n, v) { 
  8.             config[n] = v; 
  9.         } 
  10.         this.init(); 
  11.     } 
  12.     JsClassName.prototype = { 
  13.         init: function(){}, 
  14.         otherMethod: function(){} 
  15.     }; 
  16.     window.JsClassName = window.JsClassName || JsClassName; 
  17. })(window); 

使用一個自執行的匿名函數將我們的組件代碼包裹起來,盡可能的減少全局污染,最后再將我們的類附到全局window對象上,這是一種比較推薦的做法。

構造函數中的get、set方法不是必須的,只是筆者的個人習慣而已,覺得這樣寫可以將配置參數和其他組件內部全局變量緩存和讀取的調用方式統一,似乎也更具有面向對象的型。歡迎讀者們說說各自的想法,說說這樣寫到底好不好。

接下來我們一起看下Winpop組件的完整代碼:

  1. (function(window, jQuery, undefined) { 
  2.   
  3.     var HTMLS = { 
  4.         ovl: '<div class="J_WinpopMask winpop-mask" id="J_WinpopMask"></div>' + '<div class="J_WinpopBox winpop-box" id="J_WinpopBox">' + '<div class="J_WinpopMain winpop-main"></div>' + '<div class="J_WinpopBtns winpop-btns"></div>' + '</div>'
  5.         alert: '<input type="button" class="J_AltBtn pop-btn alert-button" value="確定">'
  6.         confirm: '<input type="button" class="J_CfmFalse pop-btn confirm-false" value="取消">' + '<input type="button" class="J_CfmTrue pop-btn confirm-true" value="確定">' 
  7.     } 
  8.   
  9.     function Winpop() { 
  10.         var config = {}; 
  11.         this.get = function(n) { 
  12.             return config[n]; 
  13.         } 
  14.   
  15.         this.set = function(n, v) { 
  16.             config[n] = v; 
  17.         } 
  18.         this.init(); 
  19.     } 
  20.   
  21.     Winpop.prototype = { 
  22.         init: function() { 
  23.             this.createDom(); 
  24.             this.bindEvent(); 
  25.         }, 
  26.         createDom: function() { 
  27.             var body = jQuery("body"), 
  28.                 ovl = jQuery("#J_WinpopBox"); 
  29.   
  30.             if (ovl.length === 0) { 
  31.                 body.append(HTMLS.ovl); 
  32.             } 
  33.   
  34.             this.set("ovl", jQuery("#J_WinpopBox")); 
  35.             this.set("mask", jQuery("#J_WinpopMask")); 
  36.         }, 
  37.         bindEvent: function() { 
  38.             var _this = this
  39.                 ovl = _this.get("ovl"), 
  40.                 mask = _this.get("mask"); 
  41.             ovl.on("click"".J_AltBtn", function(e) { 
  42.                 _this.hide(); 
  43.             }); 
  44.             ovl.on("click"".J_CfmTrue", function(e) { 
  45.                 var cb = _this.get("confirmBack"); 
  46.                 _this.hide(); 
  47.                 cb && cb(true); 
  48.             }); 
  49.             ovl.on("click"".J_CfmFalse", function(e) { 
  50.                 var cb = _this.get("confirmBack"); 
  51.                 _this.hide(); 
  52.                 cb && cb(false); 
  53.             }); 
  54.             mask.on("click", function(e) { 
  55.                 _this.hide(); 
  56.             }); 
  57.             jQuery(document).on("keyup", function(e) { 
  58.                 var kc = e.keyCode, 
  59.                     cb = _this.get("confirmBack");; 
  60.                 if (kc === 27) { 
  61.                     _this.hide(); 
  62.                 } else if (kc === 13) { 
  63.                     _this.hide(); 
  64.                     if (_this.get("type") === "confirm") { 
  65.                         cb && cb(true); 
  66.                     } 
  67.                 } 
  68.             }); 
  69.         }, 
  70.         alert: function(str, btnstr) { 
  71.             var str = typeof str === 'string' ? str : str.toString(), 
  72.                 ovl = this.get("ovl"); 
  73.             this.set("type""alert"); 
  74.             ovl.find(".J_WinpopMain").html(str); 
  75.             if (typeof btnstr == "undefined") { 
  76.                 ovl.find(".J_WinpopBtns").html(HTMLS.alert); 
  77.             } else { 
  78.                 ovl.find(".J_WinpopBtns").html(btnstr); 
  79.             } 
  80.             this.show(); 
  81.         }, 
  82.         confirm: function(str, callback) { 
  83.             var str = typeof str === 'string' ? str : str.toString(), 
  84.                 ovl = this.get("ovl"); 
  85.             this.set("type""confirm"); 
  86.             ovl.find(".J_WinpopMain").html(str); 
  87.             ovl.find(".J_WinpopBtns").html(HTMLS.confirm); 
  88.             this.set("confirmBack", (callback || function() {})); 
  89.             this.show(); 
  90.         }, 
  91.         show: function() { 
  92.             this.get("ovl").show(); 
  93.             this.get("mask").show(); 
  94.         }, 
  95.         hide: function() { 
  96.             var ovl = this.get("ovl"); 
  97.             ovl.find(".J_WinpopMain").html(""); 
  98.             ovl.find(".J_WinpopBtns").html(""); 
  99.             ovl.hide(); 
  100.             this.get("mask").hide(); 
  101.         }, 
  102.         destory: function() { 
  103.             this.get("ovl").remove(); 
  104.             this.get("mask").remove(); 
  105.             delete window.alert; 
  106.             delete window.confirm; 
  107.         } 
  108.     }; 
  109.   
  110.     var obj = new Winpop(); 
  111.     window.alert = function(str) { 
  112.         obj.alert.call(obj, str); 
  113.     }; 
  114.     window.confirm = function(str, cb) { 
  115.         obj.confirm.call(obj, str, cb); 
  116.     }; 
  117. })(window, jQuery); 

代碼略多,關鍵做以下幾點說明:

  • 筆者偷了懶,使用了jQuery,使用之前請先保證已經引入了jQuery
  • 自定義組件結構最終是追加到body中的,所以在引入以上js之前,請先確保文檔已經加載完成
  • 組件添加了按ESC、點遮罩層隱藏組件功能
  • 注意:雖然本例中未用到 destory 方法,但讀者朋友可以注意一下該方法中的 delete window.alert 和 delete window.confirm ,這樣寫的目的是保證在自定義組件銷毀后,將Alert、Confirm控件恢復到瀏覽器內置效果
  • 組件最后如果加上 window.Winpop = Winpop ,就可以將對象全局化供其他類調用了

最后

作為一個前端開發工程師,個人覺得Javascript組件開發是一件很有意思的事情,其中樂趣只有自己親自動手嘗試了才會體會得到。前端組件開發往往需要Javascript、CSS和html相互配合,才能事半功倍,上面提到的Winpop也不例外,這里給大家提供一個完整的demo壓縮包,有興趣的讀者朋友,歡迎傳播。

責任編輯:王雪燕 來源: 博客園
相關推薦

2022-10-17 10:28:05

Web 組件代碼

2022-03-01 11:38:51

RPC框架后端

2020-09-02 07:22:17

JavaScript插件框架

2025-06-13 09:40:45

2024-04-01 11:52:46

2013-04-25 10:40:32

unity3D手機游戲引擎

2024-04-11 08:30:05

JavaScript數組函數

2015-06-25 09:53:13

JavaScript程序員

2015-06-25 19:23:03

JavaScript程序員

2018-11-09 10:50:24

JavaScript前端

2015-06-25 09:32:55

JavaScript程序員

2018-06-19 16:04:27

Dubbo應用Java

2015-08-07 10:17:30

云應用云計算架構流暢云計算

2024-07-29 00:02:00

DemoVue開發

2016-08-04 14:08:57

前端javascripthtml

2017-03-20 17:59:19

JavaScript模板引擎

2017-03-15 08:43:29

JavaScript模板引擎

2018-11-08 16:18:07

JavaScript前端

2012-02-16 10:12:23

JavaScript

2018-01-31 15:45:07

前端Vue.js組件
點贊
收藏

51CTO技術棧公眾號

亚洲欧美制服中文字幕| 亚洲欧美自拍偷拍色图| 欧美在线视频a| 四季av中文字幕| 国产视频一区二区在线播放| 亚洲成人动漫av| 色涩成人影视在线播放| 国产叼嘿视频在线观看| 中国女人久久久| 色狠狠久久aa北条麻妃 | 天堂网在线最新版www中文网| 久久久久国产精品厨房| 99超碰麻豆| 丰满人妻一区二区三区四区| 亚洲午夜极品| 中文字幕亚洲自拍| 精品人妻一区二区免费视频| 日韩国产91| 欧美性猛交xxxx黑人猛交| 亚洲欧美一二三| 国内精品在线视频| 国产成人精品亚洲日本在线桃色| 国产极品jizzhd欧美| 91人妻一区二区三区蜜臀| 欧美精品第一区| 精品少妇一区二区三区日产乱码 | 91亚洲欧美激情| aⅴ色国产欧美| 久久亚洲精品国产亚洲老地址| 成年人在线观看av| 午夜视频在线观看精品中文| 欧美影院精品一区| 极品美女扒开粉嫩小泬| 天天干在线视频论坛| 国产精品国产精品国产专区不蜜| 狼狼综合久久久久综合网| 亚洲黄色在线免费观看| 国产一区二区三区四区五区入口| 国产欧美日韩中文字幕在线| 无码人妻aⅴ一区二区三区有奶水| 欧美特黄一级| 欧美剧在线观看| 午夜剧场免费在线观看| 日韩www.| 最近中文字幕2019免费| 亚洲无人区码一码二码三码的含义 | 成年人在线视频| 91视视频在线直接观看在线看网页在线看| 成人欧美一区二区三区视频xxx| 国产欧美日韩综合精品一区二区三区 | 亚洲精品国产setv| 亚洲国产日韩欧美在线动漫| 99riav国产精品视频| 欧美日韩午夜电影网| 91精品国产手机| 国产女同无遮挡互慰高潮91| 国产精品二区一区二区aⅴ| 亚洲午夜精品一区二区| 玖玖爱免费视频| 亚洲电影在线一区二区三区| www.性欧美| 色中色综合影院手机版在线观看| 制服丨自拍丨欧美丨动漫丨| 成人中文在线| 自拍偷拍亚洲区| 国产精品白嫩初高中害羞小美女| 国产精品三级美女白浆呻吟| 老熟妇高潮一区二区三区| 五月精品视频| 美日韩在线视频| 国产精彩视频在线| 美女精品在线| 国产精品久久久久久一区二区| www.国产福利| 免费观看a视频| 成人免费视频一区二区| 国产欧美日本在线| 猫咪在线永久网站| 中文字幕av资源一区| 一区二区三区国产福利| a篇片在线观看网站| 又紧又大又爽精品一区二区| 国产中文字幕二区| 日韩欧美一区二区三区免费观看 | 亚洲日本青草视频在线怡红院 | 日本午夜精品一区二区| av播放在线观看| 一区二区高清视频在线观看| 大肉大捧一进一出好爽视频| 成人精品国产亚洲| 日韩亚洲欧美中文三级| aaaaa级少妇高潮大片免费看| 日韩国产欧美一区二区| 欧美福利在线观看| 中文字幕日韩免费| 久久99蜜桃精品| 精品亚洲欧美日韩| 91免费在线| 亚洲在线成人精品| 亚洲精品一二三四五区| 99a精品视频在线观看| 亚洲色图激情小说| 青娱乐免费在线视频| 久久福利毛片| 岛国视频一区免费观看| 成人欧美亚洲| 午夜精品一区二区三区电影天堂| 免费涩涩18网站入口| 成人资源在线播放| 日韩中文字幕网站| 无码免费一区二区三区| 成人爱爱电影网址| 潘金莲一级淫片aaaaaa播放1| 偷拍自拍在线看| 精品免费视频.| 一级免费黄色录像| 天堂在线亚洲视频| 国产精品亚洲综合| 国产原厂视频在线观看| 欧美中文字幕一区二区三区 | 日本一区二区三区久久久久久久久不| 97av中文字幕| 999精品视频在线观看| 亚洲全黄一级网站| 丰满少妇乱子伦精品看片| 国产老肥熟一区二区三区| 亚洲一区综合| 成人涩涩视频| 亚洲欧美中文日韩v在线观看| 久久97人妻无码一区二区三区| 美腿丝袜亚洲三区| 日本一区二区三区视频免费看 | 国产日韩欧美中文| 国产尤物视频在线| 日韩欧美高清在线视频| 波多野结衣加勒比| 国产综合色产| 98国产高清一区| 在线播放免费av| 日韩欧美三级在线| 欧美成人一二三区| 国产一区二区精品在线观看| 最新精品视频| 色诱色偷偷久久综合| 中文字幕亚洲自拍| 一级黄色片免费| 中文字幕一区二区三区色视频| 亚洲欧美激情网| 91影院成人| 91久久精品国产91久久性色| www.欧美日本韩国| 日韩一级黄色大片| 国产亚洲精品久久久久久打不开| 国产成人h网站| 妺妺窝人体色777777| 高潮按摩久久久久久av免费| 久久人人爽人人| 婷婷视频在线观看| 日韩欧美aⅴ综合网站发布| 一级黄色片大全| 日产国产高清一区二区三区| 亚洲午夜久久久影院伊人| gogo大尺度成人免费视频| 俺也去精品视频在线观看| 999精品国产| 亚洲一区二区三区美女| 国产精品久久无码| 日韩精品一二区| 一区二区精品视频| 欧美一区一区| 欧美一性一乱一交一视频| 国产视频网站在线| 欧美精品久久天天躁| 免费在线观看av网址| 26uuu国产电影一区二区| 欧美成人黄色网址| 欧美1区2区3区| 精品视频一区在线| 国产亚洲人成a在线v网站| 欧美大片免费观看在线观看网站推荐| 日本精品久久久久| 欧美日韩在线播放一区| 欧美日韩大片在线观看| 26uuu亚洲| av在线免费看片| 国产一区二区三区久久久久久久久| 日韩jizzz| 久久久加勒比| 久久久这里只有精品视频| 嫩草精品影院| 日韩欧美一区二区视频| 天天综合天天干| 1000精品久久久久久久久| 玖玖爱在线精品视频| 蜜桃视频在线观看一区| 男人添女人荫蒂免费视频| 欧美日韩国产一区二区三区不卡 | 狠狠躁日日躁夜夜躁av| 精品人伦一区二区三区蜜桃免费| 自拍偷拍第9页| 99视频国产精品| 手机免费av片| 校园激情久久| 亚洲精品少妇一区二区| 精品国产乱码| 精品国产一区二区三| 超碰国产精品一区二页| 欧美最顶级的aⅴ艳星| 成人短视频在线| 亚洲最新av网址| 天天操天天干天天舔| 91精品国产欧美一区二区| 久操视频在线免费观看| 午夜视频在线观看一区| 日本中文在线视频| 国产精品美日韩| 四虎永久免费影院| 丁香激情综合国产| 成人性生交视频免费观看| 日本不卡一二三区黄网| 玩弄中年熟妇正在播放| 韩国精品一区二区三区| 欧美一级免费在线观看| 日韩精品免费| 日本欧洲国产一区二区| 偷拍精品福利视频导航| 成人免费视频网站入口| 精品一区二区三区在线观看视频| 国产精品久久久久免费a∨| 卡通欧美亚洲| 国产91精品视频在线观看| 大黄网站在线观看| 欧美激情乱人伦| 污视频在线看网站| 欧美成人免费观看| av在线免费网址| 久久精品国产免费观看| 麻豆网站在线看| 日韩性生活视频| √新版天堂资源在线资源| 国产一区二区三区四区福利| 精品乱码一区二区三四区视频| 亚洲乱码国产乱码精品精天堂| 色综合久久久久久| 亚洲经典中文字幕| 无码国精品一区二区免费蜜桃| 亚洲国产精品国自产拍av秋霞| 丰满熟女一区二区三区| 欧美成人三级在线| 黄频网站在线观看| 日韩成人av在线| 天堂а√在线8种子蜜桃视频| 精品一区二区三区四区| 青梅竹马是消防员在线| 亚洲人成电影网站色…| 91在线品视觉盛宴免费| 久久久久www| 欧美大片黄色| 97超级碰在线看视频免费在线看| 成人片免费看| 国产精选久久久久久| 欧美综合影院| 成人蜜桃视频| 亚洲色图美女| 青青草原国产免费| 狠狠爱成人网| 久草资源站在线观看| 青青草国产成人99久久| 午夜av中文字幕| 成人自拍视频在线| 实拍女处破www免费看| 中文字幕在线不卡| 国产在线视频在线观看| 欧美性xxxx在线播放| 一本色道久久综合熟妇| 精品国产免费视频| 国产三级在线免费| 免费91在线视频| 女人让男人操自己视频在线观看| 国产精品久久一| 精品国产一区二区三区性色av| 国模精品一区二区三区| 精品一区二区三| 成人午夜免费在线视频| 日韩福利电影在线| 性高潮免费视频| 欧美极品xxx| 青娱乐91视频| 欧美在线观看18| 国产 欧美 精品| 一区二区三区四区在线观看视频| 中文在线观看免费| 日本久久久久久| 一区二区三区高清在线观看| 日本不卡在线观看| 一区视频在线看| 天天色综合社区| 99在线精品观看| 91视频综合网| 欧美性大战久久久| 日韩有码第一页| 不卡伊人av在线播放| 欧美艳星kaydenkross| 99久久久精品免费观看国产| 青青草国产成人a∨下载安卓| 成人精品视频在线播放| 精品亚洲成a人在线观看| 在线不卡av电影| 亚洲v精品v日韩v欧美v专区| 国产一区二区三区四区视频| 亚洲精品视频中文字幕| www555久久| 亚洲jizzjizz日本少妇| 日本不卡高清| 亚洲一区二区蜜桃| 久久综合一区二区| 日韩高清免费av| 日韩免费视频一区| 麻豆视频在线免费观看| 国产精品久久久久av| 天天操综合520| 国内精品视频一区二区三区| 国产精品一区二区在线观看网站| 影音先锋男人看片资源| 色88888久久久久久影院野外| 五月婷婷在线播放| 久久久久久成人| 18国产精品| 黄网站色视频免费观看| 国产综合久久久久影院| 九九这里只有精品视频| 欧美日韩精品一区二区三区| 国产区视频在线| 国产精品第一区| 精品一区二区三| 超碰在线公开97| 国产精品久久久久久久久免费樱桃| 亚洲精品久久久久久久蜜桃| 亚洲美女激情视频| 成人美女黄网站| 欧美资源一区| 日本午夜精品一区二区三区电影| 西西444www无码大胆| 在线视频观看一区| 91在线品视觉盛宴免费| 国产免费一区二区三区在线能观看 | 日韩人妻精品中文字幕| 亚洲乱码av中文一区二区| 欧美羞羞视频| 亚洲精品中文字幕在线| 精品一二三四在线| 人妻少妇精品一区二区三区| 欧美群妇大交群的观看方式| 黄色网页在线免费观看| 亚洲伊人第一页| 伊人成人在线| 国产国语性生话播放| 一本大道av一区二区在线播放| 国产亚洲依依| 国产日韩精品视频| 欧美精品午夜| 天堂久久久久久| 色屁屁一区二区| 浪潮av一区| 国产欧美一区二区三区另类精品 | 精品区一区二区| 九色在线视频观看| 污污的视频在线观看| 337p粉嫩大胆色噜噜噜噜亚洲| v8888av| 欧美自拍偷拍一区| 免费观看久久久久| **亚洲第一综合导航网站| 一区视频在线| 亚洲理论片在线观看| 欧美卡1卡2卡| 黑人另类精品××××性爽| 国产精品久久久久aaaa九色| 成人在线免费观看| 日韩美女视频免费在线观看| 国产精品99一区二区三区| 99中文字幕在线| 亚瑟在线精品视频| jizz日韩| 国产亚洲欧美一区二区| 蜜臀va亚洲va欧美va天堂 | 高清毛片aaaaaaaaa片| 国产suv精品一区二区三区88区| 婷婷综合五月| 噜噜噜在线视频| 91精选在线观看| 成人免费网站视频| 国产 国语对白 露脸| 久久久久久99精品| www.四虎在线观看| 国产精品成人一区二区三区吃奶 | 成人三级视频在线播放| 亚洲三级小视频| 国产精品国产高清国产| 91亚洲精品在线观看|