日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

開發(fā)一個(gè)完整的JavaScript組件

瀏覽:24日期:2023-11-20 18:24:11

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

功能介紹取代瀏覽器自帶的Alert、Confirm控件自定義界面樣式使用方式與內(nèi)置控件基本保持一致效果預(yù)覽

1、Alert控件

開發(fā)一個(gè)完整的JavaScript組件

2、Confirm控件

開發(fā)一個(gè)完整的JavaScript組件

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

開發(fā)過程

1. 組件結(jié)構(gòu)設(shè)計(jì)

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

alert("內(nèi)置Alert控件"); if (confirm("關(guān)閉內(nèi)置Confirm控件?")) { alert("True"); } else { alert("False"); }

為了保證我們的組件使用方式和內(nèi)置控件保持一致,所以我們必須考慮覆蓋內(nèi)置控件??紤]到組件開發(fā)的風(fēng)格統(tǒng)一,易用,易維護(hù),以及面向?qū)ο蟮忍匦?,我?jì)劃將自定義的alert和confirm方法作為一個(gè)類(Winpop)的實(shí)例方法,最后用實(shí)例方法去覆蓋系統(tǒng)內(nèi)置控件的方法。為了達(dá)到目的,我的基本做法如下:

var obj = new Winpop(); // 創(chuàng)建一個(gè)Winpop的實(shí)例對象// 覆蓋alert控件window.alert = function(str) { obj.alert.call(obj, str);};// 覆蓋confirm控件window.confirm = function(str, cb) { obj.confirm.call(obj, str, cb);};

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

alert("自定義Alert組件");confirm("關(guān)閉自定義Confirm組件?", function(flag){ if (flag) {alert("True"); } else {alert("False"); }});

2. 組件代碼設(shè)計(jì)

在正式介紹Winpop組件的代碼之前,我們先來看一下一個(gè)Javascript組件的基本結(jié)構(gòu):

(function(window, undefined) { function JsClassName(cfg) {var config = cfg || {};this.get = function(n) { return config[n];}this.set = function(n, v) { config[n] = v;}this.init(); } JsClassName.prototype = {init: function(){},otherMethod: function(){} }; window.JsClassName = window.JsClassName || JsClassName;})(window);

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

構(gòu)造函數(shù)中的get、set方法不是必須的,只是筆者的個(gè)人習(xí)慣而已,覺得這樣寫可以將配置參數(shù)和其他組件內(nèi)部全局變量緩存和讀取的調(diào)用方式統(tǒng)一,似乎也更具有面向?qū)ο蟮男?。歡迎讀者們說說各自的想法,說說這樣寫到底好不好。

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

(function(window, jQuery, undefined) { var HTMLS = {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>',alert: '<input type="button" class="J_AltBtn pop-btn alert-button" value="確定">',confirm: '<input type="button" class="J_CfmFalse pop-btn confirm-false" value="取消">' + '<input type="button" class="J_CfmTrue pop-btn confirm-true" value="確定">' } function Winpop() {var config = {};this.get = function(n) { return config[n];}this.set = function(n, v) { config[n] = v;}this.init(); } Winpop.prototype = {init: function() { this.createDom(); this.bindEvent();},createDom: function() { var body = jQuery("body"),ovl = jQuery("#J_WinpopBox"); if (ovl.length === 0) {body.append(HTMLS.ovl); } this.set("ovl", jQuery("#J_WinpopBox")); this.set("mask", jQuery("#J_WinpopMask"));},bindEvent: function() { var _this = this,ovl = _this.get("ovl"),mask = _this.get("mask"); ovl.on("click", ".J_AltBtn", function(e) {_this.hide(); }); ovl.on("click", ".J_CfmTrue", function(e) {var cb = _this.get("confirmBack");_this.hide();cb && cb(true); }); ovl.on("click", ".J_CfmFalse", function(e) {var cb = _this.get("confirmBack");_this.hide();cb && cb(false); }); mask.on("click", function(e) {_this.hide(); }); jQuery(document).on("keyup", function(e) {var kc = e.keyCode, cb = _this.get("confirmBack");;if (kc === 27) { _this.hide();} else if (kc === 13) { _this.hide(); if (_this.get("type") === "confirm") {cb && cb(true); }} });},alert: function(str, btnstr) { var str = typeof str === 'string' ? str : str.toString(),ovl = this.get("ovl"); this.set("type", "alert"); ovl.find(".J_WinpopMain").html(str); if (typeof btnstr == "undefined") {ovl.find(".J_WinpopBtns").html(HTMLS.alert); } else {ovl.find(".J_WinpopBtns").html(btnstr); } this.show();},confirm: function(str, callback) { var str = typeof str === 'string' ? str : str.toString(),ovl = this.get("ovl"); this.set("type", "confirm"); ovl.find(".J_WinpopMain").html(str); ovl.find(".J_WinpopBtns").html(HTMLS.confirm); this.set("confirmBack", (callback || function() {})); this.show();},show: function() { this.get("ovl").show(); this.get("mask").show();},hide: function() { var ovl = this.get("ovl"); ovl.find(".J_WinpopMain").html(""); ovl.find(".J_WinpopBtns").html(""); ovl.hide(); this.get("mask").hide();},destory: function() { this.get("ovl").remove(); this.get("mask").remove(); delete window.alert; delete window.confirm;} }; var obj = new Winpop(); window.alert = function(str) {obj.alert.call(obj, str); }; window.confirm = function(str, cb) {obj.confirm.call(obj, str, cb); };})(window, jQuery);

代碼略多,關(guān)鍵做以下幾點(diǎn)說明:

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

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

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
美女尤物久久精品| 久久激情av| yellow在线观看网址| 国产在线一区不卡| 精品视频91| 国产一区国产二区国产三区| 国产一区调教| 日韩成人a**站| 日韩在线中文| 久久三级福利| 日韩视频一区二区三区在线播放免费观看| 一本一道久久a久久精品蜜桃| 好吊一区二区三区| 精品中文字幕一区二区三区av| 欧美在线亚洲| 综合国产在线| 国产欧美一区二区三区米奇| 精品无人区麻豆乱码久久久 | 最新亚洲一区| 中文一区二区| 日韩欧美2区| 久久精品国产99国产| 麻豆视频在线看| 久久久久久久久99精品大| 91久久黄色| 日韩精品国产欧美| 国产乱人伦丫前精品视频| 国产精品对白| 五月激情久久| 亚洲自啪免费| 欧美日本一区| 欧美久久天堂| 亚洲欧美日韩专区| 国产精品久一| 欧美日韩尤物久久| 亚洲色图综合| 久久中文字幕一区二区三区| 蜜桃成人精品| 蜜臀av性久久久久蜜臀aⅴ流畅| 欧美偷窥清纯综合图区| 激情国产在线| 一级欧洲+日本+国产| 亚洲人成网站在线在线观看| 精品一区二区三区在线观看视频 | 麻豆成人在线| 另类综合日韩欧美亚洲| 久久人人97超碰国产公开结果| 蜜桃久久av一区| 丰满少妇一区| 亚洲欧美久久久| 久久亚洲精品中文字幕| 日韩午夜在线| 精品国内亚洲2022精品成人| 亚洲黄色在线| 久久精品99国产精品日本| 日韩不卡在线| 欧美亚洲tv| 亚洲国产综合在线看不卡| 日韩黄色av| 99精品综合| 国产日韩视频在线| 亚洲精品一区二区在线看| 91av一区| 亚洲男女av一区二区| 国产激情久久| 鲁大师影院一区二区三区| 国产成人精品三级高清久久91| 久久国产精品毛片| 黑人精品一区| 视频一区中文字幕国产| 中文一区一区三区高中清不卡免费| 色狠狠一区二区三区| 亚洲一级少妇| 欧美一级全黄| 樱桃成人精品视频在线播放| 国产精品xx| 国产伦乱精品| 美女被久久久| 欧美一区二区性| 精品午夜久久| 日韩av二区在线播放| 欧美.日韩.国产.一区.二区| 久久久亚洲欧洲日产| 天堂av一区| 久久影院一区| 精品国产免费人成网站| 国产欧美另类| 手机精品视频在线观看| 亚洲大片在线| 国产精选在线| 国产九一精品| 日本成人在线网站| 巨乳诱惑日韩免费av| 欧美日中文字幕| 精品视频网站| 国产精品一区二区精品 | 日韩一区精品视频| 欧美午夜不卡| 成人在线观看免费视频| 日本精品国产| 在线观看亚洲精品福利片| 99国产精品免费视频观看| 国产一区二区色噜噜| 国产日韩精品视频一区二区三区| 最新亚洲国产| 性色av一区二区怡红| 一区二区三区四区在线看| 日韩动漫一区| 美国三级日本三级久久99| 91嫩草精品| 亚洲久久视频| 亚洲精品激情| 久久久久九九精品影院| 久久不见久久见免费视频7 | 午夜久久久久| 好看的av在线不卡观看| 亚洲大全视频| 亚洲二区在线| 尹人成人综合网| 欧美网站在线| 麻豆久久精品| 亚洲三级国产| 欧美日韩精品一区二区三区在线观看| 日韩av一级片| 国产精品毛片久久久| 精品国产中文字幕第一页| 国产精品久久久一区二区| 欧美日韩国产一区二区在线观看| 青青青国产精品| 国产欧美日韩在线一区二区| 国产精品视频一区视频二区| 国产精品日本一区二区不卡视频| 国产一精品一av一免费爽爽| 久久xxx视频| 国产不卡精品在线| 日韩一区二区在线免费| 欧美/亚洲一区| 免费观看在线色综合| 啪啪亚洲精品| 国产精品白丝av嫩草影院| 国产一区丝袜| 国产va在线视频| 国产99精品| 视频一区中文字幕国产| 久久精品97| 国产91欧美| 国产尤物精品| 美国三级日本三级久久99| 欧美日韩夜夜| 国产一区二区三区日韩精品| se01亚洲视频| 美日韩精品视频| 久久国产日韩欧美精品| 国产一区不卡| 中文在线一区| 国产情侣一区在线| 精品国内亚洲2022精品成人| 激情欧美一区| 日韩在线电影| av中文字幕在线观看第一页| 在线亚洲观看| 国产精品视频一区二区三区综合| 日韩在线不卡| 日韩在线播放一区二区| 国产精品美女午夜爽爽| 亚洲精品.com| 中文字幕乱码亚洲无线精品一区| 国产激情久久| 亚洲先锋成人| 日精品一区二区三区| 精品久久不卡| 亚洲午夜精品久久久久久app| 日韩一区免费| 亚洲va中文在线播放免费| 麻豆久久精品| 久久精品理论片| 亚洲精品在线观看91| 国产三级一区| 不卡中文字幕| 国产精品1区| 欧美日韩国产在线一区| 国产精品一区二区三区www| 欧美成人基地| 日本不卡高清视频| 日韩中文字幕高清在线观看| 亚洲日本在线观看视频| 久久午夜影院| 蜜桃久久av一区| 日韩亚洲一区在线| 日韩av中文字幕一区二区| 91精品一区二区三区综合| 日本不卡一二三区黄网| 欧美三级网址| 日本午夜精品一区二区三区电影| 天堂中文av在线资源库| 日韩av不卡一区二区| 黑丝一区二区三区| 精品一区二区三区四区五区| 免费国产亚洲视频| 电影天堂国产精品|