Javascript如何實現(xiàn)擴充基本類型
可以通過給Function.prototype增加方法來使得該方法對所有函數(shù)可用。
通過給Function.prototype增加一個method方法,下次給對象增加方法的時候就不必鍵入prototype這幾個字符了。
Function.prototype.method=function(name,func){ this.prototype[name]=func; return this;}
一、JavaScript增加整數(shù)類型
JavaScript沒有專門的整數(shù)類型,但有時候確實只需要提前數(shù)字中的整數(shù)部分。
可以給Number.prototype增加一個integer方法。
inter()方法根據(jù)數(shù)字的正負來判斷是使用Math.ceiling還是Math.floor。
Number.method(’integer’,function(){ return Math[this<0?’ceil’:’floor’](this);});document.writeln((-10/3).integer());//-3
二、JavaScript缺少一個移除字符串首尾空白的方法
String.method(’trim’,function(){ return this.replace(/^s+|s+$/g,’’);});document.writeln(’ ' ’+' neat '.trim() +’ ' ’);//' neat '
基本類型的原型是公用結構,所以在類庫混用時務必小心。一個保險的做法就是只在確定沒有該方法時才添加它。
Function.prototype.method=function(name,func){ if(!this.prototype[name]){ this.prototype[name]=func; } return this;}
new前綴去調(diào)用一個函數(shù)
Function.method(’new’,function () { //創(chuàng)建一新對象,它繼承自構造器函數(shù)的原型對象。 var that=Object.create(this.prototype); //調(diào)用構造器函數(shù),綁定-this-到新對象上。 var other=this.apply(that,arguments); //如果它的返回值不是一個對象,就返回該對象。 return (typeof other===’object’&&other)||that;});
superior
Object.method(’superior’,function(name){ //傳入方法名name var that=this,method=that[name]; return function(){ return method.apply(that,argumetns); }});
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關文章:
1. php模擬實現(xiàn)斗地主發(fā)牌2. Python random庫使用方法及異常處理方案3. 理解PHP5中static和const關鍵字4. spring acegi security 1.0.0 發(fā)布5. Vue封裝一個TodoList的案例與瀏覽器本地緩存的應用實現(xiàn)6. Vuex localStorage的具體使用7. jQuery 實現(xiàn)DOM元素拖拽交換位置的實例代碼8. .Net Core使用Coravel實現(xiàn)任務調(diào)度的完整步驟9. vue 使用localstorage實現(xiàn)面包屑的操作10. MyBatis中的JdbcType映射使用詳解

網(wǎng)公網(wǎng)安備