您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“JS常見的API擴展形式有哪些”,內容詳細,步驟清晰,細節處理妥當,希望這篇“JS常見的API擴展形式有哪些”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
比如我現在有一個需求,給定一個字符串,給方法傳遞一個參數為數字類型來確定當前字符串重復次數,例如:
'abc'.repeatStringNumTimes(3)?//?abcabcabc
如果按照一般的思維就是我們把這個方法綁定到String的原型上,如下代碼:
String.prototype.repeatStringNumTimes?=?String.prototype.repeatStringNumTimes?||?function(times)?{var?str?=?'';for(var?i?=?0;?i?<?times;?i++)?{
str?+=?this;
}return?str;
}
jQuery插件開發方式主要有三種:
通過$.extend()來擴展jQuery
通過$.fn 向jQuery添加新的方法
通過$.widget()應用jQuery UI的部件工廠方式創建
通常我們使用第二種方法來進行簡單插件開發,說簡單是相對于第三種方式。第三種方式是用來開發更高級jQuery部件的,該模式開發出來的部件帶有很多jQuery內建的特性,比如插件的狀態信息自動保存,各種關于插件的常用方法等,非常貼心,這里不細說。
而第一種方式又太簡單,僅僅是在jQuery命名空間或者理解成jQuery身上添加了一個靜態方法而以。所以我們調用通過。extend()添加的函數時直接通過。extend()添加的函數時直接通過符號調用($.myfunction())而不需要選中DOM元素($('#example')。myfunction())。請看下面的例子。
$.extend({
sayHello:?function(name)?{
console.log('Hello,'?+?(name?name?:?'Dude')?+?'!');
}
})
$.sayHello();?//調用$.sayHello('Wayou');?//帶參調用
看一個jquery封裝的面向對象的插件開發代碼:
//定義Beautifier的構造函數var?Beautifier?=?function(ele,?opt)?{this.$element?=?ele,this.defaults?=?{'color':?'red','fontSize':?'12px','textDecoration':'none'
},this.options?=?$.extend({},?this.defaults,?opt)
}//定義Beautifier的方法Beautifier.prototype?=?{
beautify:?function()?{return?this.$element.css({'color':?this.options.color,'fontSize':?this.options.fontSize,'textDecoration':?this.options.textDecoration
});
}
}//在插件中使用Beautifier對象$.fn.myPlugin?=?function(options)?{//創建Beautifier的實體
var?beautifier?=?new?Beautifier(this,?options);//調用其方法
return?beautifier.beautify();
}
調用方式:
$(function()?{
$('a')。myPlugin({'color':?'#2C9929','fontSize':?'20px'
});
})
讀到這里,這篇“JS常見的API擴展形式有哪些”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。