JavaScript設(shè)計(jì)模式--簡(jiǎn)單工廠模式實(shí)例分析【XHR工廠案例】
本文實(shí)例講述了JavaScript設(shè)計(jì)模式--簡(jiǎn)單工廠模式。分享給大家供大家參考,具體如下:
第一步,Ajax操作接口(目的是起一個(gè)接口檢測(cè)作用)
(1)引入接口文件
//定義一個(gè)靜態(tài)方法來(lái)實(shí)現(xiàn)接口與實(shí)現(xiàn)類的直接檢驗(yàn)
//靜態(tài)方法不要寫(xiě)出Interface.prototype ,因?yàn)檫@是寫(xiě)到接口的原型鏈上的
//我們要把靜態(tài)的函數(shù)直接寫(xiě)到類層次上
//(1)定義一個(gè)接口類
var Interface=function (name,methods) {//name:接口名字
if(arguments.length<2){
alert("必須是兩個(gè)參數(shù)")
}
this.name=name;
this.methods=[];//定義一個(gè)空數(shù)組裝載函數(shù)名
for(var i=0;i<methods.length;i++){
if(typeof methods[i]!="string"){
alert("函數(shù)名必須是字符串類型");
}else {
this.methods.push( methods[i]);
}
}
};
Interface.ensureImplement=function (object) {
if(arguments.length<2){
throw new Error("參數(shù)必須不少于2個(gè)")
return false;
}
for(var i=1;i<arguments.length;i++){
var inter=arguments[i];
//如果是接口就必須是Interface類型
if(inter.constructor!=Interface){
throw new Error("如果是接口類的話,就必須是Interface類型");
}
//判斷接口中的方法是否全部實(shí)現(xiàn)
//遍歷函數(shù)集合
for(var j=0;j<inter.methods.length;j++){
var method=inter.methods[j];//接口中所有函數(shù)
//object[method]傳入的函數(shù)
//最終是判斷傳入的函數(shù)是否與接口中所用函數(shù)匹配
if(!object[method]||typeof object[method]!="function" ){//實(shí)現(xiàn)類中必須有方法名字與接口中所用方法名相同
throw new Error("實(shí)現(xiàn)類中沒(méi)有完全實(shí)現(xiàn)接口中的所有方法")
}
}
}
}
第二步,實(shí)例化一個(gè)可以具體的ajax接口
var AjaxHandler=new Interface("AjaxHandler",["request","createXhrObject"]);
第三步,針對(duì)接口的ajax實(shí)現(xiàn)類
(1)定義一個(gè)空類
var SimpleHandler=function(){};
(2)在該空類上直接擴(kuò)展原型---實(shí)現(xiàn)接口里面的方法
SimpleHandler.prototype={
/*
* method:get post
* url:請(qǐng)求地址
* callback:回調(diào)函數(shù)
* postVars:傳入?yún)?shù)
* */
request:function (method,url,callback,postVars) {
//1,使用工廠得到xhr對(duì)象
var xhr=this.createXhrObject();
xhr.onreadystatechange=function () {
//4代表的意思是交互完成
if(xhr.readyState!=4) return;
//200值的是正常交互完成
//404文件未找到
//500 內(nèi)部程序出錯(cuò)
(xhr.status==200)?callback.success(xhr.responseText,xhr.responseXML):
callback.failure(xhr.status);
}
//打開(kāi)鏈接
xhr.open(method,url,true);
//設(shè)置參數(shù)
if(method!="POST"){
postVars=null;
}
xhr.send(postVars);
},
//2,獲取xhr的方法--不同瀏覽器不一樣
createXhrObject:function () {
var methods=[
function () {return new XMLHttpRequest();},
function () {return new ActiveXObject("Microsoft.XMLHTTP");}
];
//利用try--catch 制作一個(gè)智能循環(huán)體
for(var i=0;i<methods.length;i++){
try{
methods[i]();
}catch(e) {
continue;//回到循環(huán)開(kāi)始的地方重新開(kāi)始
}
this.createXhrObject=methods[i]();//非常重要,只有這樣才能確保不用每一次請(qǐng)求,全循環(huán)數(shù)組
return methods[i]();
}
//如果全不對(duì)則報(bào)錯(cuò)
throw new Error("error");
}
};
第三步,使用檢驗(yàn)
(1)實(shí)例化對(duì)象
var myHandler=new SimpleHandler();
(2)接口檢驗(yàn)實(shí)現(xiàn)類是否完全實(shí)現(xiàn)接口中的方法
Interface.ensureImplement(myHandler,AjaxHandler); //檢驗(yàn)是否實(shí)現(xiàn)接口中所有方法
(3)定義一個(gè)回調(diào)對(duì)象
var callback={
success:function (responseText) {
alert("ok");
},
failure:function (status) {
alert(status+"failure")
}
};
(4)最終的使用格式
myHandler.request("POST","http://www.baidu.com",callback);
//若url為""會(huì)默認(rèn)為本地的鏈接,其他正確的鏈接,會(huì)出現(xiàn)跨域問(wèn)題
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
JS實(shí)現(xiàn)表單中checkbox對(duì)勾選中增加邊框顯示效果
這篇文章主要介紹了JS實(shí)現(xiàn)表單中checkbox對(duì)勾選中增加邊框顯示效果,可實(shí)現(xiàn)點(diǎn)擊后圖片增加邊框及勾選的功能,非常簡(jiǎn)潔實(shí)用,需要的朋友可以參考下2015-08-08
uniapp實(shí)現(xiàn)上拉加載更多功能的全過(guò)程
我們?cè)陧?xiàng)目中經(jīng)常使用到上拉加載更多,下面這篇文章主要給大家介紹了關(guān)于uniapp實(shí)現(xiàn)上拉加載更多功能的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10
js實(shí)現(xiàn)提交前對(duì)列表數(shù)據(jù)的增刪改查
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)提交前對(duì)列表數(shù)據(jù)的增刪改查,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-01-01
如何用js將blob為pcm格式轉(zhuǎn)換為MP3格式
要將PCM文件轉(zhuǎn)換為MP3文件,您可以使用Js實(shí)現(xiàn),這篇文章主要給大家介紹了關(guān)于如何用js將blob為pcm格式轉(zhuǎn)換為MP3格式的相關(guān)資料,需要的朋友可以參考下2023-11-11
Javascript中獲取出錯(cuò)代碼所在文件及行數(shù)的代碼
之前在做一個(gè)Javascript的日志控制臺(tái)功能模塊,希望能夠在Javascript代碼出錯(cuò)時(shí)捕獲此錯(cuò)誤,并將出錯(cuò)的文件及相應(yīng)的行數(shù)打印到控制臺(tái)并匯報(bào)給服務(wù)器。2010-09-09

