zoukankan      html  css  js  c++  java
  • 理顺 JavaScript (16) 使用 prototype


    给对象增减方法
    function Rect(w, h) {
      this.width = w;
      this.height = h;
    }
    
    var r = new Rect(2, 3);
    
    /* 给 r 对象增加一个计算面积的方法 area() */
    r.area = function() {return this.width * this.height};
    
    alert(r.width);  //2
    alert(r.height); //3
    alert(r.area()); //6
    
    delete r.area; //删除刚刚增加的方法
    alert(r.area); //undefined
    

    给类增减方法
    function Rect(w, h) {
      this.width = w;
      this.height = h;
    }
    
    var r = new Rect(2, 3);
    
    /* 给 r 对象所属的类增加一个计算面积的方法 area() */
    Rect.prototype.area = function() {return this.width * this.height};
    
    alert(r.width);  //2
    alert(r.height); //3
    alert(r.area()); //6
    
    /* 给类(而不是对象)增加的方法会影响到旗下所有对象 */
    var r2 = new Rect(4, 5);
    alert(r2.width);  //4
    alert(r2.height); //5
    alert(r2.area()); //20
    
    delete Rect.prototype.area; //删除刚刚给类增加的方法
    alert(r.area);              //undefined
    

    给其他类增加方法
    /* 给 Array 增加一个倒排序的方法 */
    Array.prototype.usort = function() {this.sort(); this.reverse()}; //该函数写得太凑合了
    
    var arr = new Array(1,3,2,4,3,5);
    arr.sort();
    alert(arr); //1,2,3,3,4,5
    arr.usort();
    alert(arr); //5,4,3,3,2,1
    
    /* 假如给 Object 增加一个方法 */
    Object.prototype.msg = function() {alert('我无处不在!');}
    
    var obj = {};
    obj.msg(); //我无处不在!
    
    var arr = [];
    arr.msg(); //我无处不在!
    
    var str = '';
    str.msg(); //我无处不在!
    

  • 相关阅读:
    总结第一、二类斯特林数(模板)
    总结组合数的几种求法(模板)
    HDU5521 Meeting(dijkstra+巧妙建图)
    BZOJ4152 The Captain(dijkstra+巧妙建图)
    CF1194D 1-2-K Game (博弈论)
    JavaScript字符串的操作
    JavaScript基础–闭包
    JavsScript基础–声明提升
    JavaScript基础–作用域
    css基础(一)
  • 原文地址:https://www.cnblogs.com/del/p/1402884.html
Copyright © 2011-2022 走看看