react 学习持续更新

首先react语法是基于jsfiddle  

开始 Hack React 的最简单的方法是用下面 JSFiddle 的 Hello Worlds:

<!DOCTYPE html>
<html>
  <head>
    <script src="build/react.js"></script>
    <script src="build/JSXTransformer.js"></script>
  </head>
  <body>
    <div id="example"></div>
    <script type="text/jsx">
      React.render(
        <h1>Hello, world!</h1>,
        document.getElementById('example')
      );
    </script>
  </body>
</html>

在 JavaScript 代码里写着 XML 格式的代码称为 JSX;可以去 <a rel="nofollow" href="http://facebook.github.io/react/docs/jsx-in-depth.html" "="" style="padding: 0px; margin: 0px; background-color: rgb(255, 255, 255); color: rgb(45, 133, 202); font-family: Verdana, "Lantinghei SC", "Hiragino Sans GB", "Microsoft Yahei", Helvetica, arial, 宋体, sans-serif; font-size: 14px; text-align: start;">JSX 语法 里学习更多 JSX 相关的知识。为了把 JSX 转成标准的 JavaScript,我们用 <script type="text/jsx"> 标签包裹着含有 JSX 的代码,然后引入 JSXTransformer.js库来实现在浏览器里的代码转换。

熟悉这种语法糖的使用

和jsx类似的还有 coffeescript typescript  原理最终都是被解析成js


1、改变样式

或者css 

 这里name就是props里面的key值

2、生命周期


每个状态都包含will和did两个状态  即为即将做的和已经完成的

 update会把当前state和最近一次的state对比 从而发生改变


改变初始值:



取键值也是可以的


为啥要用箭头函数  如果是在timeout或者自定义函数里面的话  this指向一般指global对象  也就是window

插:

[document对象]

  该对象是window和frames对象的一个属性,是显示于窗口或框架内的一个文档。

  属性

  alinkColor 活动链接的颜色(ALINK)
  anchor 一个HTMI锚点,使用<A NAME=>标记创建(该属性本身也是一个对象)
  anchors array 列出文档锚点对象的数组(<A NAME=>)(该属性本身也是一个对象)
  bgColor 文档的背景颜色(BGCOLOR)
  cookie 存储于cookie.txt文件内的一段信息,它是该文档对象的一个属性
  fgColor 文档的文本颜色(<BODY>标记里的TEXT特性)
  form 文档中的一个窗体(<FORM>)(该属性本身也是一个对象)
  forms anay 按照其出现在文档中的顺序列出窗体对象的一个数组(该属性本身也是一个对象)
  lastModified 文档最后的修改日期
  linkColor 文档的链接的颜色,即<BODY>标记中的LINK特性(链接到用户没有观察到的文档)
  link 文档中的一个<A HREF=>标记(该属性本身也是一个对象)
  links array 文档中link对象的一个数组,按照它们出现在文档中的顺序排列(该属性本身也是一个对象)
  location 当前显示文档的URL。用户不能改变document.location(因为这是当前显示文档的位置)。但是,可以改变window.location (用其它文档取代当前文档)window.location本身也是一个对象,而document.location不是对象
  referrer 包含链接的文档的URL,用户单击该链接可到达当前文档
  title 文档的标题((TITLE>)
  vlinkColor 指向用户已观察过的文档的链接文本颜色,即<BODY>标记的VLINK特性

  方法

  clear 清除指定文档的内容
  close 关闭文档流
  open 打开文档流
  write 把文本写入文档
  writeln 把文本写入文档,并以换行符结尾

[window对象]

  它是一个顶层对象,而不是另一个对象的属性即浏览器的窗口。

  属性

  defaultStatus 缺省的状态条消息
  document 当前显示的文档(该属性本身也是一个对象)
  frame 窗口里的一个框架((FRAME>)(该属性本身也是一个对象)
  frames array 列举窗口的框架对象的数组,按照这些对象在文档中出现的顺序列出(该属性本身也是一个对象)
  history 窗口的历史列表(该属性本身也是一个对象)
  length 窗口内的框架数
  location 窗口所显示文档的完整(绝对)URL(该属性本身也是一个对象)不要把它与如document.location混淆,后者是当前显示文档的URL。用户可以改变window.location(用另一个文档取代当前文档),但却不能改变document.location(因为这是当前显示文档的位置)
  name 窗口打开时,赋予该窗口的名字
  opener 代表使用window.open打开当前窗口的脚本所在的窗口(这是Netscape Navigator 3.0beta 3所引入的一个新属性)
  parent 包含当前框架的窗口的同义词。frame和window对象的一个属性
  self 当前窗口或框架的同义词
  status 状态条中的消息
  top 包含当前框架的最顶层浏览器窗口的同义词
  window 当前窗口或框架的同义词,与self相同

  方法

  alert() 打开一个Alert消息框
  clearTimeout() 用来终止setTimeout方法的工作
  close() 关闭窗口
  confirm() 打开一个Confirm消息框,用户可以选择OK或Cancel,如果用户单击OK,该方法返回true,单击Cancel返回false
  blur() 把焦点从指定窗口移开(这是Netscape Navigator 3.0 beta 3引入的新方法)
  focus() 把指定的窗口带到前台(另一个新方法)
  open() 打开一个新窗口
  prompt() 打开一个Prompt对话框,用户可向该框键入文本,并把键入的文本返回到脚本
  setTimeout() 等待一段指定的毫秒数时间,然后运行指令事件处理程序

  事件处理程序

  Onload() 页面载入时触发
  Onunload() 页面关闭时触发


this指向问题:箭头函数、自己保存this,还有就是bind函数

mounting可以添加两个hook函数:

  还有就是这个函数用来初始化数据 用法参见上面

updating的hook


  当需要接受新的props时候调用  一个参数 就是新的props

接收了新的props和state之后判断是否有必要去更新dom 两个参数  新的props和新的state对象,返回true是更新 反之。

unmounting:实例销毁

执行cleanup的操作  比如释放内存资源与图片资源,不过浏览器辣鸡回收机制已经帮我们做到了  一般不会自己去清除

垃圾回收机制

3、事件的绑定:

  提示:react.render第一个对象传的是dom  如果是多个组件  用div包起来

驼峰命名法绑定事件:


上面这样写是不对的  因为react并不是操作的真实dom,所以我们要借助handelclick

 使用react.findDOMNode封装好的方法找到实际生成的dom

阻止冒泡:

onchange事件:


注意的几个点:

1、组件的首字母必须大写,不然不报错也不显示。

2、0.13以后版本 var tipE = React,findDOMNode(this.refs.tip); 直接改写成 var tipE = this.refs.tip; 

3、React.findDOMNode()会报错:Uncaught TypeError: React.findDOMNode is not a function

    用ReactDom.findDOMNode()就好了

4、React.findDOMNode(this.refs.tip) 报错的话,只需要改成ReactDOM.findDOMNode(this.refs.tip)即可,因为版本更新后,findDOMNode方法是属于ReactDOM的了。

另外改成var tipEle=this.refs.tip 也可以,不需要再用findDOMNode方法。

进阶:

视频传送门

input绑定值新写法


异步发送ajax




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风儿轻丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值