针对学习react.js中,我感觉最大的疑惑点就是bind(this)的绑定和指向问题了,我被这个问题弄的头昏,有时候调用组件的时候,直接显示undefined,不存在这个组件,当时的心情是崩溃的,整个人的状态是不好的,所以今天要好好学习bind(this)这个问题。

在我们创建一个组件的时候,会在他的父组件调用这个子组件,这是,这个组件的指向就是这个父组件了,但是在子组件内部的一些指向就不能使用了,因为在这个父组件中不存在这个子组件所包含的属性,此时,就需要使用bind(this)来绑定这个子组件,这样,这个子组件中函数的指向就是这个子组件自身了。

var Father = React.createClass({

  click:function(){

    //函数的一些业务逻辑

  },

  render:function(){

    return (

      //父级函数包含一个组件,并添加了一些属性,并具有业务逻辑

      <List click={this.click} />

    )

  }

})

var List= React.createClass({

  render:function(){

    <ul>

      //在子组件中调用这个函数的时候,如果不添加bind(this),这个函数的指向就是 li ,而不是这个click函数,所以需要添加bind(this)绑定这个函数指向正确

      <li onClick={this.props.click.bind(this)}>name</li>

    </ul>

  }

})

在es5和es6中,有时候匿名函数会指向undefined和window,这是如果方法体内需要使用到当前的组件的this,就可以使用bind(this)进行绑定

其实我感觉整体来说,对于bind(this)绑定来说,可以说是在自己的组件创立,但是在其他地方调用的时候,因为指向已经改变了,所以,需要使用bing(this),让这个组件依然可以指向自己组件内部就可以了。

整体来说就是这样了,就看你的组件调用到什么地方了,,,好了,大概思路就是这样了

还有一种情况,就是bind(this,i,item),不仅绑定了this,还绑定了更多的参数,这个怎么理解呢,这个其实在react 的API上有介绍,但是当时看这个教程一眼带过,没有细看,现在饭回来看就可以理解了,地址:http://reactjs.cn/react/tips/communicate-between-components.html

var handleClick = function(i, props) {

  console.log('You clicked: ' + props.items[i]);

}

function GroceryList(props) {

return (

  <div> {props.items.map(function(item, i) {

    return (

       <div onClick={handleClick.bind(this, i, props)} key={i}>{item}</div> ); }

    )}

  </div> );

}

ReactDOM.render( <GroceryList items={['Apple', 'Banana', 'Cranberry']} />, mountNode );

具体解释可以这么理解,对于handleClick(i ,props) 这个函数中,含有两个参数,在调用这个组件的时候,我们绑定了这个函数,这一点没有问题,但是有的会疑惑后面的i

和props是什么鬼,这里有解释:

注意使用bind(this, arg1, arg2, ...):我们只是传递更多的参数handleClick。这不是一个新的React概念; 它只是JavaScript。

也就是这个不是react的bind(this)的一个概念,这个是我们前面创建的handleClick (i,props)函数里面传递的两个参数,只是在bind(this)的后面添加这个函数了而已。

react.js学习之路四的更多相关文章

  1. react.js学习之路二

    看react.js对我来说真的不是难不难的问题,问题是我的思路太难转变了,真是坑死我了,react里面的坑也很多.算了,这些抱怨没啥用,记录一下今天学习的内容. 今天看了to-do-list经典示例 ...

  2. react.js学习之路三

    学习react.js,知识点整理: 1.props和state: props是相对于父级来说,固定的不会改变的内容.一般会先定义一个变量,则在父级中进行引用, var user = "liu ...

  3. react.js学习之路一

    今天新老大来了,我们要学习他使用的框架react.js,现在是两眼一抹黑,对于我这个前端菜鸟来说,是真正的重新开始,好了,不说那么多了,开始随便记录我的学习,之后再整理内容. (1)对于react来说 ...

  4. react.js学习之路六

    学习react中,我一直认为,总组件里面才有构造函数,但是我才发现我的观点是错误的,构造函数是可以出现在子组件里面的. 今天有一个错误是点击增加/减少input框里面 的数值 我一直在寻找input框 ...

  5. react.js学习之路五

    最近没时间写博客,但是我一直在学习react,我发现react是一个巨大的坑,而且永远填不完的坑 关于字符串的拼接: 在react中,字符串的拼接不允许出现双引号“” ,只能使用单引号' ',例如这样 ...

  6. 【温故知新】——BABYLON.js学习之路·前辈经验(二)

    前言:在上一篇随笔BABYLON.js学习之路·前辈经验(一)中回顾了组内同事们长时间在Babylon开发实践中的总结出的学习之路和经验,这一篇主要对开发中常见的一些功能点做一个梳理,这里只作为温故知 ...

  7. React.js学习

    React.js学习之环境搭建 1 工欲善其事必先利其器:前端开发工具 1.1 WebStorm和Sublime Text Sublime Text:作为代码编辑器,Sublime Text的优点如下 ...

  8. React.js学习知识小结(一)

    学习React也有半个月了吧,这里对所学的基础知识做个简单的总结.自己先是跟着官方文档学,差不多学了四五天,也跟着入门教程做了一个简单的小栗子.然后跟着阮一峰老师的教程上手了几个小Demo,后来在网上 ...

  9. React.js学习小结

    最近一段时间都在学习React.js,感觉还不错,现在把自己的一些学习笔记记录一下,留着以后学习查看. 0.React全家桶(技术栈) 1.React主体 2.WebPack:grunt.gulp自动 ...

随机推荐

  1. Unity3D版本之我见

    关心Unity版本的变化以及了解未来版本的内容是专业做Unity的同学必备的功课,下面我来说一下我对4.0以后版本的一些见解. v4.0: 这个版本比3.5有较大的跳跃,首先最大卖点是新的动作系统Me ...

  2. VS加载项目时报错 尚未配置为Web项目XXXX指定的本地IIS

    网上找的几个方法都不行 最后自己解决了.首先打开该项目得csproj文件,找到<ProjectExtensions>这个标签,是在最后部分,然后把<UseIIS>True< ...

  3. WEB扫描器Atscan的安装和使用

    项目地址:https://github.com/AlisamTechnology/ATSCAN root@sch01ar:/sch01ar# git clone https://github.com/ ...

  4. MFC 文档/视图

    1.文档修改后,关闭时需要保存,主要用到2个函数,在需要更改文档内容的函数里调用SetModifiedFlag(TRUE),另一个就是SaveModified()函数,简单的例子: BOOL CMFC ...

  5. nginx反向代理负载均衡初次配置

    反向代理,我个人理解是通过一台反向代理服务器,把客户端的把有请求按照一定的规则分发给后台的服务器.nginx作反向代理服务器的虚拟机配置如下: upstream itest { #正常情况下应该作如下 ...

  6. winform 如何正确的获取窗体的标题栏高度

    最近我需要知道鼠标在一个控件里的相对位置,鼠标相对于屏幕的位置我是可以知道的,所以只要得到控件相对于屏幕的位置,就可以算出鼠标相对于控件的位置了 但是发现有误差 后来经过测试是由于窗体的标题栏高度导致 ...

  7. 1.forEach():遍历数组,并为每个元素调用传入的函数; 举例:

    var a = [1,2,3]; var sum = 0; //传一个参数 a.forEach(function(v){ sum += v; }); console.log(sum);//6 //传三 ...

  8. vware 中 red hat linux NAT模式上网配置

    NAT模式的具体配置NAT方式:虚拟机可以上外网,可以访问宿主计算机所在网络的其他计算机(反之不行). 未修改之前的eth0

  9. 【bzoj2115】[Wc2011] Xor

    2115: [Wc2011] Xor Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 2512  Solved: 1049[Submit][Status ...

  10. scrapy设置代理

    在爬取网站内容的时候,最常遇到的问题是:网站对IP有限制,会有防抓取功能,最好的办法就是IP轮换抓取(加代理) 下面来说一下Scrapy如何配置代理,进行抓取 1.在Scrapy工程下新建“middl ...