中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 用 prototype 定義自己的方法
頭部屬性全接觸 回到列表 JS 小游戲
 用 prototype 定義自己的方法

作者:windy2000 時間: 2003-12-05 文檔類型:原創(chuàng) 來自:藍色理想

本文是本人通過個人理解所寫成的,沒有參照任何資料,如有雷同,純屬巧合,同時,如果您要引用本文文字,請注明 — 作者:windy_sk;Email:seasonx@163.net,謝謝!

  本文進通過實例,講述通過 prototype 自定義方法的過程,旨在拋磚引玉,如果不對的地方,歡迎指正!

  prototype 是在 IE 4 及其以后版本引入的一個針對于某一類的對象的方法,而且特殊的地方便在于:它是一個給類的對象添加方法的方法!這一點可能聽起來會有點亂,別急,下面我便通過實例對這一特殊的方法作已下講解:

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

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


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


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

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


2、已有方法的實現(xiàn)和增強,初識 prototype:
(1) Array.push(new_element)
  作用:在數(shù)組末尾加入一個新的元素
  實現(xiàn)方法:
  Array.prototype.push = function(new_element){
        this[this.length]=new_element;
        return this.length;
    }
  讓我們進一步來增強他,讓他可以一次增加多個元素!
  實現(xiàn)方法:
  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)該不難看懂吧?以此類推,你可以考慮一下如何通過增強 Array.pop 來實現(xiàn)刪除任意位置,任意多個元素(具體代碼就不再細說了)

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


3、新功能的實現(xiàn),深入 prototype:在實際編程中所用到的肯定不只是已有方法的增強,更多的實行的功能的要求,下面我就舉兩個用 prototype 解決實際問題的例子:
(1) String.left()
  問題:用過 vb 的應(yīng)該都知道left函數(shù),從字符串左邊取 n 個字符,但是不足是將全角、半角均視為是一個字符,造成在中英文混排的版面中不能截取等長的字符串
  作用:從字符串左邊截取 n 個字符,并支持全角半角字符的區(qū)分
  實現(xiàn)方法:
  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);
    }
  試驗:alert("aa啦啦aa".left(4)) -> 顯示 aa啦啦
     alert("aa啦啦aa".left(4,true)) -> 顯示 aa啦
  本方法用到了上面所提到的String.Tlength()方法,自定義方法之間也能組合出一些不錯的新方法呀!

(2) Date.DayDiff()
  作用:計算出兩個日期型變量的間隔時間(年、月、日、周)
  實現(xiàn)方法:
  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));
    }
  試驗:alert((new Date()).DayDiff((new Date(2002,0,1)))) -> 顯示 329
     alert((new Date()).DayDiff((new Date(2002,0,1)),"m")) -> 顯示 10
  當(dāng)然,也可以進一步擴充,得出響應(yīng)的小時、分鐘,甚至是秒。

(3) Number.fact()
  作用:某一數(shù)字的階乘
  實現(xiàn)方法:
  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());
    }
  試驗:alert((4).fact()) -> 顯示 24
  這個方法主要是說明了遞歸的方法在 prototype 方法中也是可行的!

我編的一些字符串增強方法:http://www.95time.cn/bbs/NewsDetail.asp?id=716195

出處:藍色理想
責(zé)任編輯:panliu888

◎進入論壇網(wǎng)頁制作網(wǎng)站綜合版塊參加討論

相關(guān)文章 更多相關(guān)鏈接
JavaScript實用的一些技巧
js 幾種常用的表單輸入判斷
js實現(xiàn)單機雙人象棋演示及其分析
Javascript 表單之間的數(shù)據(jù)傳遞
JS 216網(wǎng)頁安全色調(diào)色板 DW 風(fēng)格
作者文章 更多作者文章
用 onerror 獲取錯誤信息
用 Quick Click 練習(xí)鼠標(biāo)定位
Javascript 編寫的文字放大效果
將 html 轉(zhuǎn)成 ubb代碼的小腳本
用 prototype 定義自己的方法
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標(biāo)配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2