zoukankan      html  css  js  c++  java
  • js修改函数内部的this指向(bind,call,apply)

    js修改函数内部的this指向


    在调用函数的时候偶尔在函数内部会使用到this,在使用this的时候发现并不是我们想要指向的对象.可以通过bind,call,apply来修改函数内部的this指向.

    默认在浏览器下script标签内定义的函数,调用的时候函数内部的this指向window(浏览器窗口对象)

    <script>
    var a=2
    function hello(){
        console.log(this)       
        console.log(this.a)      
    }
    hello() 
    //输出: window => object 
    //输出: 2
    </script>
    

      

    使用bind来修改内部的this指向 bind(option) 函数内部的this指向option这个对象

    <script>
    var a=2
    var obj={
        a:"a"
    }
    function hello(){
        console.log(this)       
        console.log(this.a)    
    }
    hello=hello.bind(obj)
    hello()
    //输出: obj => { a:'a' }
    //输出: 'a'
    </script>
    

      

    使用call来修改内部的this指向 call(option) 函数内部的this指向option这个对象

    var a=2
    var obj={
        a:"a"
    }
    function hello(){
        console.log(this)      
        console.log(this.a)     
    }
    hello.call(obj)
    //输出: obj => { a:'a' }
    //输出: 'a'
    

      

    使用apply来修改内部的this指向 apply(option) 函数内部的this指向option这个对象

    var a=2
    var obj={
        a:"a"
    }
    function hello(){
        console.log(this)      
        console.log(this.a)     
    }
    hello.apply(obj)
    //输出: obj => { a:'a' }
    //输出: 'a'
    

      

    bind ,call ,apply 的区别

    • bind是只改变函数内部this指向,但不自调用
    • call,apply 改变函数内部指向并且自调用
    • call第一个参数是需要指向的对象,之后的参数是函数内部的形参可以访问
    • apply第一个参数是需要指向的对象,第二个参数是数组格式,函数内部的形参可以访问
    //call
    var a = 2
    var obj={
        a:'a'
    }
    function hello(a, b, c) {
        console.log(this)
        console.log(a, b, c)
    }
    hello.call(obj,1,2,3)  // { a:'a' }  1,2,3
    
    //apply
    var a = 2
    var obj={
        a:'a'
    }
    function hello(a, b, c) {
        console.log(this)
        console.log(a, b, c)
    }
    hello.apply(obj,[1,2],3,4)  // { a:'a' }  1,2,undefind,undefind
    

      

  • 相关阅读:
    反射、枚举
    WebService、Http请求、Socket请求
    RPC和REST的区别
    命名分组
    golang isPowerOfTwo判断是否是2的幂
    golang 判断平台是32位还是64位
    vue的permission.js详解
    windows 下完全卸载oracle 11的详细过程
    freemarker导出word
    freemarker详细教程从入门到精通(三)模板入门与指令
  • 原文地址:https://www.cnblogs.com/kongyijilafumi/p/13235836.html
Copyright © 2011-2022 走看看