bind,apply,call的区别及实现

共同点

bind,apply和call都可以改变使用对象的this指向

不同点

1.bind绑定不会立即执行,需要手动调用
2.apply,call绑定函数会立即执行,如果传入的第一个参数是null,undefined则this指向window。apply和call的区别是:apply第二个参数是一个数组,而call从第二个参数起后面传入的都是单个的参数。

手写apply,call,bind

1.手写call

Function.prototype.myCall = function(context){
    context = context || window
    context.fn = this
    let args = [...arguments]
    args.shift()
    const res = context.fn(...args)
    delete context.fn
    return res 
}
//测试代码
function Apple(){}
Apple.prototype = {
    color: 'red',
    say: function(){
        console.log(`this.color is ${this.color}`)
    }
}
const banana = {
    color: 'yellow'
}
 
const apple = new Apple();
apple.say.myCall(banana) // this.color is yellow
// 传入null ,this就指向window, window.color没有值,返回undefined
apple.say.myCall(null) // this.color is undefined

2.手写apply

Function.prototype.myApply = function(context,arr){
    context = context || window
    context.fn = this
    let res = null
    if(!arr){
        res = context.fn()
    }
    let args = [...arr]
    res = context.fn(...args)
    delete context.fn
    return res 
}
//测试代码
function Apple(){}
Apple.prototype = {
    color: 'red',
    say: function(a,b){
        console.log(`this.color is ${this.color}`)
        console.log('a',a,'b',b)
    }
}
const banana = {
    color: 'yellow'
}
 
const apple = new Apple();
apple.say.myApply(banana,[1,2]) 
// this.color is yellow
// a 1 b 2
// 传入null ,this就指向window, window.color没有值,返回undefined
apple.say.myApply(banana,null) // this.color is yellow
// a undefined b undefined

3.手写bind

第一种:借助apply

Function.prototype.myBind = function(){
    const _this = this
   // 获取第一个参数,要指向的this对象
    const firstArg = Array.prototype.shift.call(arguments)
   // 获取剩余的参数
    const args = Array.prototype.slice.call(arguments)
    return function(){
        // 获取内部函数的所有参数
        const innerArg = Array.prototype.slice.call(arguments)
        const lastArg = args.concat(innerArg)
        _this.apply(firstArg,lastArg)
    }
}

第二种:不借助apply

Function.prototype.myBind = function(){
    const _this = this
    const context = Array.prototype.shift.call(arguments)
    const args = Array.prototype.slice.call(arguments)
    return function(){
        const innerArg = Array.prototype.slice.call(arguments)
        const lastArg = args.concat(innerArg)
        context.fn = _this
        const resut = context.fn(...lastArg)
        delete context.fn
        return resut
    }
}

4.实现一个new关键字

function Person(){}
function newFun(name,age){
    const newObject = new Object()
    Person.call(newObject,name,age)
    newObject.__proto__ = Person.prototype
    return newObject
}

手写节流和防抖

节流

//节流 时间戳
function throttle(fn,delay){
    let pre = 0
    return function(){
        const context = arguments
        const _this = this
        const now = +Date.now()
        if(now - pre > delay){
            fn.apply(_this,context)
            pre = now
        }
    }
}
// 节流 定时器
function throttle(fn,delay){
    let timer = null
    return function(){
        const context = arguments
        const _this = this
        if(!timer){
            timer = setTimeout(()=>{
                fn.apply(_this,context)
                timer = null
            },delay)
        }    
    }
}

防抖

function debounce(fn,delay){
    let timer = null
    return function(){
        const args = arguments
        const _this = this
        clearTimeout(timer)
        timer = setTimeout(()=>{
            fn.apply(_this,args)
            timer = null
        },delay)
            
    }
}

排序算法

1.冒泡

function bubbleSort1(arr) {
    if (arr.length < 2) {
        return arr;
    }
    // 定义 count 代表执行了趟循环
    let count = 0;
    // 冒泡排序排的趟数=数组的长度-1
    // 第一层 for 循环代表一共排序多少趟
    for (let i = 0; i < arr.length - 1; i++) {
        count++;
        let hasSort = true;
        // 第二层 for 循环代表每趟需要比较多少次 每趟比较的次数会减i,因为每趟会将最后排好一个元素,排了多少趟,则代表排好了几个元素
        for (let j = 0; j < arr.length - 1 - i; j++) {
            // 在大于的时候才会交换,等于的时候不交换,所以冒泡排序属于稳定排序算法,不会对相等两个元素执行交换
            // j=>左指针,j + 1=>右指针
            if (arr[j] > arr[j + 1]) {
                // 只要交换过,则不是有序
                hasSort = false;
                let temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
        if (hasSort) {
            break;
        }
    }
    console.log(`执行了${count}趟循环`);
    return arr;
}

2.快排

function qucikSort1(arr){
    if(arr.length <= 1) return arr
    const pre = arr.splice(0,1)
    let left = [],right = []
    arr.forEach(item=>{
        if(item < pre){
            left.push(item)
        }else {
          right.push(item)
        }
    })
   return qucikSort1(left).concat(pre).concat(qucikSort1(right))
}
qucikSort1([2,4,1,6]) // [1, 2, 4, 6]
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容