亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

js筆記三十五之原型鏈模式擴展(2)

標簽:
JavaScript

在原型模式中,this常用的有两种情况:

  1. 在类中 this.xxx=xxx; this -> 当前类的实例

  2. 某一个方法中的this -> 看执行的时候 . 前面是谁this就是谁

    1. 需要先确定this的指向(this是谁);

    2. 把this替换成对应的代码

    3. 按照原型链查找机制, 一步步的查找结果

function Fn(){    this.x = 100;    this.y = 200;
}
Fn.prototype = {    constructor: Fn,    y: 300,    getX: function(){        console.log(this.x)
    },    getY: function(){        console.log(this.y)
    }
}var f = new Fn;
f.getX() // -> 100  => console.log(f.x) => 100f.__proto__.getX() // -> undefined  => this是f.__proto__ => console.log(f.__proto__.x)[忽略私有,直接找原型] => undefinedFn.prototype.getX(); // -> undefinedf.getY(); // -> 200f.__proto__getY() // -> 300
// 在内置类的原型上扩展数组去重方法Array.prototype.myUnique = function(){    // this -> 
    var obj = {};    for(var i=0;i<this.length;i++){        var cur = this[i]        if(obj[cur] == cur){            this[i] = this[this.length - 1];            this.length--;
            i--;            continue;
        }
        obj[cur] = cur;
    }
    obj = null;    return this; // 目的是为了实现链式写法}var ary = [12,23,23,13,12,13,23,13,12];
ary.myUnique();console.log(ary)// Array.prototype.myUnique() // -> this -> Array.prototype

链式写法: 执行完成数组的一个方法可以紧接着执行下一个方法
ary为什么可以使用sort方法? -> 因为sort是Array.prototype上的公有的方法,而数组ary是Array这个类的一个实例,所以ary可以使用sort方法 -> 数组才能使用Array原型上定义的属性和方法
sort执行完成的返回值是一个排序后的数组,可以继续执行reverse
reverse执行完成的返回值是一个数组,可以继续执行pop
pop执行完成的返回值是一个被删除的那个元素

ary.sort(function(a,b){    return a-b;
}).reverse().pop();

思考练习:

在数组的原则上有一个方法叫做slice, 自己实现一个方法mySlice, 要求和原来的slice功能一模一样

Array.prototype.mySlice = function(){    // js code...}

考虑情况:
slice(n,m)
slice(n)
slice()
n和m是负数
n<m
n和m的值超过数组的长度
n和m不是有效数字
...



作者:uplyw
链接:https://www.jianshu.com/p/b3f5c151ed82


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消