js中的bind方法和函数中成员

Posted 流世幻羽

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js中的bind方法和函数中成员相关的知识,希望对你有一定的参考价值。

1,认识js中bind的方法

   //复制了一份的时候,把参数传入到了f1函数中,x===>10,y===>20,null就是this,默认就是window
    //bind方法是复制的意思,参数可以在复制的时候传进去,也可以在复制之后调用的时候传入进去
    //apply和call是调用的时候改变this指向
    //bind方法,是赋值一份的时候,改变了this的指向

function f1(x,y){
	console.log((x+y)+":=====>"+this.age);
}
var ff=f1.bind(null);

ff(10,29);
//让person调用这个

function Person() {
  this.age = 1000;
}

var p=new Person();

var ff=f1.bind(p,10,20);
ff();



console.log("==========================");

 function Person(age) {
      this.age=age;
    }
    Person.prototype.play=function () {
      console.log(this+"====>"+this.age);
    };

    function Student(age) {
      this.age=age;
      console.log(age);
    }
    var per=new Person(10);
    var stu=new Student(20);
    //复制了一份,执行的是stu中的方法
    var ff=per.play.bind(stu);
    ff();
    //bind是用来复制一份
    //使用的语法:
    /*
    * 函数名字.bind(对象,参数1,参数2,...);---->返回值是复制之后的这个函数
    * 方法名字.bind(对象,参数1,参数2,...);---->返回值是复制之后的这个方法
	*/

2.bind使用的小案例

//通过对象,调用方法,产生随机数

    function ShowRandom() {
      //1-10的随机数
      this.number=parseInt(Math.random()*10+1);
    }
    //添加原型方法
    ShowRandom.prototype.show1=function () {
      //改变了定时器中的this的指向了,本来应该是window,现在是实例对象了
      window.setInterval(this.show2.bind(this),1000);
    };
    //添加原型方法
    ShowRandom.prototype.show2=function () {
      //显示随机数--
      console.log(this.number);
    };
    //实例对象
    var sr=new ShowRandom();
    //调用方法,输出随机数字
    //调用这个方法一次,可以不停的产生随机数字
    sr.show1();

3.函数中的成员

  //函数中有一个name属性----->函数的名字,name属性是只读的,不能修改
    //函数中有一个arguments属性--->实参的个数
    //函数中有一个length属性---->函数定义的时候形参的个数
    //函数中有一个caller属性---->调用(f1函数在f2函数中调用的,所以,此时调用者就是f2)
    function f1(x,y) {
      console.log(f1.name);
      console.log(f1.arguments.length);
      console.log(f1.length);
      console.log(f1.caller);//调用者
    }
//    f1.name="f5";
//    f1(10,20,30,40);
//    console.dir(f1);


    function f2() {
      console.log("f2函数的代码");
      f1(1,2);
    }
    f2();

  

以上是关于js中的bind方法和函数中成员的主要内容,如果未能解决你的问题,请参考以下文章

JS中的callapplybind方法详解

理解JS中的callapplybind方法

理解JS中的callapplybind方法

理解JS中的callapplybind方法()

前端随心记---------call,bind,apply

SOCKET编程中的bind函数的作用