call()和apply()用法和两者区别

    // 1.每个函数都包含两个非继承而来的方法call()和apply().
        // 2.相同点:call()和apply()的作用都一样:改变this的指向

        // call()的用法:
        window.color = 'pink'
        document.color = 'red'
        var C = {
            color: 'blue'
        }
        function f1() {
            console.log(this.color);
        }
        f1.call() // 默认指向window
        f1.call(window)//pink
        f1.call(document)//red
        f1.call(C)//blue

        var pet = {
            words: '...',
            speak: function (say) {
                console.log(say + '' + this.words);
            },
        }
        pet.speak("陈")
        var s = {
            words: '斌'
        }
        pet.speak.call(s, '陈')

        // apply的用法
        function pet2(words) {
            this.words = words
            this.speak = function () {
                console.log(this.words);
            }
        }
        function dog(words) {
            pet2.call(this, words) // 陈
            pet2.apply(this, arguments)// 陈
        }
        //    console.log(window);
        var Dog = new dog('陈')
        Dog.speak()

        //    call和apply不同点
        // 1.传递的参数不同
        // call和apply传递的第一个参数相同都是this的指向作用域,call传递的第二个参数需要一一列举出来,而apply第二个参数是一个数组
        function add(c, d) {
            console.log(this.a + this.b + c + d);
        }
        var s = { a: 1, b: 2 }
        add.call(s, 5, 6) //14
        add.apply(s, [7, 8]) // 18

        // apply的巧妙用处:
        // apply的第二个参数是一个数组,但是程序处理的时候是将这个数组转换成了参数列表例如[1,2,3,4]--->(1,2,3,4)
        // 例子1:
        // 当我们需要在一个数组中获取最大的或者最小的值时,可以直接使用apply()方法
        var arr = [1, 2, 34, 6, 57, 43]
        console.log(Math.max.apply(null, arr));// 57
        console.log(Math.min.apply(null, arr));// 1
        // 这块在调用的时候第一个参数给了一个null,这个是因为没有对象去调用这个方法,我只需要用这个方法帮我运算,得到返回的结果就行,.所以直接传递了一个null过去
        // 例子2:
        // Array prototype.push(),在数组的的末尾添加元素
        var arr1 = [1,2,3]
        var arr2 = ["a","b","c"]
        
        arr1.push(4) 
        console.log(arr1); //[1, 2, 3, 4]
        
        Array.prototype.push.apply(arr1, arr2) //此时会将arr2数组转换成参数列表('a','b','c')
        console.log(arr1); //[1, 2, 3, 6, "a", "b", "c"]
posted @ 2019-10-31 23:38  天天向上啊  阅读(251)  评论(0编辑  收藏  举报