欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript prototype屬性使用說(shuō)明

 更新時(shí)間:2010年05月13日 19:02:28   作者:  
prototype 是在 IE 4 及其以后版本引入的一個(gè)針對(duì)于某一類(lèi)的對(duì)象的方法,而且特殊的地方便在于:它是一個(gè)給類(lèi)的對(duì)象添加方法的方法!
這一點(diǎn)可能聽(tīng)起來(lái)會(huì)有點(diǎn)亂,別急,下面我便通過(guò)實(shí)例對(duì)這一特殊的方法作已下講解:

  首先,我們要先了解一下類(lèi)的概念,JavaScript 本身是一種面向?qū)ο蟮恼Z(yǔ)言,它所涉及的元素根據(jù)其屬性的不同都依附于某一個(gè)特定的類(lèi)。我們所常見(jiàn)的類(lèi)包括:數(shù)組變量(Array)、邏輯變量(Boolean)、日期變量(Date)、結(jié)構(gòu)變量(Function)、數(shù)值變量(Number)、對(duì)象變量(Object)、字符串變量(String) 等,而相關(guān)的類(lèi)的方法,也是程序員經(jīng)常用到的(在這里要區(qū)分一下類(lèi)的注意和屬性發(fā)方法),例如數(shù)組的push方法、日期的get系列方法、字符串的split方法等等,

  但是在實(shí)際的編程過(guò)程中不知道有沒(méi)有感覺(jué)到現(xiàn)有方法的不足?prototype 方法應(yīng)運(yùn)而生!下面,將通過(guò)實(shí)例由淺入深講解 prototype 的具體使用方法:


1、最簡(jiǎn)單的例子,了解 prototype:
(1) Number.add(num):作用,數(shù)字相加
實(shí)現(xiàn)方法:Number.prototype.add = function(num){return(this+num);}
試驗(yàn):alert((3).add(15)) -> 顯示 18


(2) Boolean.rev(): 作用,布爾變量取反
實(shí)現(xiàn)方法:Boolean.prototype.rev = function(){return(!this);}
試驗(yàn):alert((true).rev()) -> 顯示 false

是不是很簡(jiǎn)單?這一節(jié)僅僅是告訴讀者有這么一種方法,這種方法是這樣運(yùn)用的。


2、已有方法的實(shí)現(xiàn)和增強(qiáng),初識(shí) prototype:
(1) Array.push(new_element)
  作用:在數(shù)組末尾加入一個(gè)新的元素
  實(shí)現(xiàn)方法:
復(fù)制代碼 代碼如下:

  Array.prototype.push = function(new_element){
this[this.length]=new_element;
return this.length;
}

  讓我們進(jìn)一步來(lái)增強(qiáng)他,讓他可以一次增加多個(gè)元素!
  實(shí)現(xiàn)方法:
復(fù)制代碼 代碼如下:

  Array.prototype.pushPro = function() {
var currentLength = this.length;
for (var i = 0; i < arguments.length; i++) {
this[currentLength + i] = arguments[i];
}
return this.length;
}

  應(yīng)該不難看懂吧?以此類(lèi)推,你可以考慮一下如何通過(guò)增強(qiáng) Array.pop 來(lái)實(shí)現(xiàn)刪除任意位置,任意多個(gè)元素(具體代碼就不再細(xì)說(shuō)了)

(2) String.length
  作用:這實(shí)際上是 String 類(lèi)的一個(gè)屬性,但是由于 JavaScript 將全角、半角均視為是一個(gè)字符,在一些實(shí)際運(yùn)用中可能會(huì)造成一定的問(wèn)題,現(xiàn)在我們通過(guò) prototype 來(lái)彌補(bǔ)這部不足。
  實(shí)現(xiàn)方法:
  String.prototype.cnLength = function(){
var arr=this.match(/[^\x00-\xff]/ig);
return this.length+(arr==null?0:arr.length);
}
  試驗(yàn):alert("EaseWe空間Spaces".cnLength()) -> 顯示 16
  這里用到了一些正則表達(dá)式的方法和全角字符的編碼原理,由于屬于另兩個(gè)比較大的類(lèi)別,本文不加說(shuō)明,請(qǐng)參考相關(guān)材料。


3、新功能的實(shí)現(xiàn),深入 prototype:在實(shí)際編程中所用到的肯定不只是已有方法的增強(qiáng),更多的實(shí)行的功能的要求,下面我就舉兩個(gè)用 prototype 解決實(shí)際問(wèn)題的例子:
(1) String.left()
  問(wèn)題:用過(guò) vb 的應(yīng)該都知道left函數(shù),從字符串左邊取 n 個(gè)字符,但是不足是將全角、半角均視為是一個(gè)字符,造成在中英文混排的版面中不能截取等長(zhǎng)的字符串
  作用:從字符串左邊截取 n 個(gè)字符,并支持全角半角字符的區(qū)分
  實(shí)現(xiàn)方法:
復(fù)制代碼 代碼如下:

  String.prototype.left = function(num,mode){
if(!/\d+/.test(num))return(this);
var str = this.substr(0,num);
if(!mode) return str;
var n = str.Tlength() - str.length;
num = num - parseInt(n/2);
return this.substr(0,num);
}

  試驗(yàn):
alert("EaseWe空間Spaces".left(8)) -> 顯示 EaseWe空間
alert("EaseWe空間Spaces".left(8,true)) -> 顯示 EaseWe空
  本方法用到了上面所提到的String.Tlength()方法,自定義方法之間也能組合出一些不錯(cuò)的新方法呀!

(2) Date.DayDiff()
  作用:計(jì)算出兩個(gè)日期型變量的間隔時(shí)間(年、月、日、周)
  實(shí)現(xiàn)方法:
復(fù)制代碼 代碼如下:

  Date.prototype.DayDiff = function(cDate,mode){
try{
cDate.getYear();
}catch(e){
return(0);
}
var base =60*60*24*1000;
var result = Math.abs(this - cDate);
switch(mode){
case "y":
result/=base*365;
break;
case "m":
result/=base*365/12;
break;
case "w":
result/=base*7;
break;
default:
result/=base;
break;
}
return(Math.floor(result));
}

  試驗(yàn):alert((new Date()).DayDiff((new Date(2002,0,1)))) -> 顯示 329
alert((new Date()).DayDiff((new Date(2002,0,1)),"m")) -> 顯示 10
  當(dāng)然,也可以進(jìn)一步擴(kuò)充,得出響應(yīng)的小時(shí)、分鐘,甚至是秒。

(3) Number.fact()
  作用:某一數(shù)字的階乘
  實(shí)現(xiàn)方法:
復(fù)制代碼 代碼如下:

  Number.prototype.fact=function(){
var num = Math.floor(this);
if(num<0)return NaN;
if(num==0 || num==1)
return 1;
else
return (num*(num-1).fact());
}

  試驗(yàn):alert((4).fact()) -> 顯示 24
  這個(gè)方法主要是說(shuō)明了遞歸的方法在 prototype 方法中也是可行的!

相關(guān)文章

  • 7. Microsoft Online-Crash Control, version 6.0(微軟在線(xiàn)崩潰控件)

    7. Microsoft Online-Crash Control, version 6.0(微軟在線(xiàn)崩潰控件)

    7. Microsoft Online-Crash Control, version 6.0(微軟在線(xiàn)崩潰控件)...
    2007-08-08
  • 淺談js構(gòu)造函數(shù)的方法與原型prototype

    淺談js構(gòu)造函數(shù)的方法與原型prototype

    下面小編就為大家?guī)?lái)一篇淺談js構(gòu)造函數(shù)的方法與原型prototype。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-07-07
  • 一文帶你了解JavaScript垃圾回收機(jī)制

    一文帶你了解JavaScript垃圾回收機(jī)制

    JS自帶一套內(nèi)存管理引擎,負(fù)責(zé)創(chuàng)建對(duì)象、銷(xiāo)毀對(duì)象,以及垃圾回收,下面這篇文章主要給大家介紹了關(guān)于JavaScript垃圾回收機(jī)制的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-11-11
  • 原生js實(shí)現(xiàn)點(diǎn)擊輪播切換圖片

    原生js實(shí)現(xiàn)點(diǎn)擊輪播切換圖片

    這篇文章主要為大家詳細(xì)介紹了原生js點(diǎn)擊輪播切換圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • js實(shí)現(xiàn)彈窗暗層效果

    js實(shí)現(xiàn)彈窗暗層效果

    本文主要分享了js實(shí)現(xiàn)彈窗暗層效果的示例代碼。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-01-01
  • Js類(lèi)的構(gòu)建與繼承案例詳解

    Js類(lèi)的構(gòu)建與繼承案例詳解

    這篇文章主要介紹了Js類(lèi)的構(gòu)建與繼承案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • JavaScript進(jìn)制轉(zhuǎn)換實(shí)現(xiàn)方法解析

    JavaScript進(jìn)制轉(zhuǎn)換實(shí)現(xiàn)方法解析

    這篇文章主要介紹了JavaScript進(jìn)制轉(zhuǎn)換實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了JavaScript進(jìn)制轉(zhuǎn)換中十進(jìn)制與其他進(jìn)制轉(zhuǎn)換、以及隨機(jī)顏色生成相關(guān)操作技巧,需要的朋友可以參考下
    2020-01-01
  • javascript 隨機(jī)數(shù) 與高級(jí)應(yīng)用 附vbscript(asp) 隨機(jī)數(shù)總結(jié)

    javascript 隨機(jī)數(shù) 與高級(jí)應(yīng)用 附vbscript(asp) 隨機(jī)數(shù)總結(jié)

    有時(shí)忘了程序的隨機(jī)數(shù)函數(shù)或javascript和vbscript的隨機(jī)數(shù)混亂了,特總結(jié)下兩者的隨機(jī)數(shù)函數(shù),以備以后使用方便。
    2007-10-10
  • 微信小程序分享海報(bào)生成的實(shí)現(xiàn)方法

    微信小程序分享海報(bào)生成的實(shí)現(xiàn)方法

    為了吸引更多的用戶(hù),設(shè)計(jì)好一個(gè)分享海報(bào)還是很有必要的,這篇文章主要介紹了微信小程序分享海報(bào)生成的實(shí)現(xiàn)方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-12-12
  • 微信上傳視頻文件提示(推薦)

    微信上傳視頻文件提示(推薦)

    晚上要下班了老板發(fā)來(lái)一個(gè)任務(wù):把一個(gè)300M左右的視頻壓縮到100M以?xún)?nèi),以便在微信上發(fā)送。于是就是抽空搞了起來(lái),下面小編把過(guò)程分享到腳本之家平臺(tái),需要的朋友參考下吧
    2018-11-11

最新評(píng)論