React 万能的函数表达式
2015-12-16 00:13
671 查看
一、语法简介
表达式可以以下两种方法,
(1)(function A(){})(this),(this)参数在函数外面
(2)(function B(){}(this)),(this)参数在函数里面
(1)和(2)的区别在于,(1)的左边的一对括号是强制A()求值,返回函数的引用,再传this参数调用函数求值,而(2)是把(this)传给A(),直接返回函数的返回值,而不是函数引用本身。
方式一:
方式二:
运行结果:
表达式可以以下两种方法,
(1)(function A(){})(this),(this)参数在函数外面
(2)(function B(){}(this)),(this)参数在函数里面
(1)和(2)的区别在于,(1)的左边的一对括号是强制A()求值,返回函数的引用,再传this参数调用函数求值,而(2)是把(this)传给A(),直接返回函数的返回值,而不是函数引用本身。
方式一:
<!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <script src="./react-0.13.2/build/react.js"></script> <script src="./react-0.13.2/build/JSXTransformer.js"></script> <script type="text/jsx"> var style = { color : "red", border: "1px #000 solid", }; var HelloWorld = React.createClass({ render: function(){ return <p>你好, { (function(obj){ if(obj.props.name) return obj.props.name else return "World!" })(this) }</p>; } }); React.render(<div style={style}><HelloWorld name="李小龙!"></HelloWorld></div>, document.body); </script> </body> </html>
方式二:
<!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <script src="./react-0.13.2/build/react.js"></script> <script src="./react-0.13.2/build/JSXTransformer.js"></script> <script type="text/jsx"> var style = { color : "red", border: "1px #000 solid", }; var HelloWorld = React.createClass({ render: function(){ return <p>你好, { (function(obj){ if(obj.props.name) return obj.props.name else return "World!" }(this)) }</p>; } }); React.render(<div style={style}><HelloWorld name="李小龙!"></HelloWorld></div>, document.body); </script> </body> </html>
运行结果:
![](http://images2015.cnblogs.com/blog/653056/201512/653056-20151216001305146-260567698.png)
相关文章推荐
- 通过表达式、函数给React组件属性赋值
- react-native源码分析系列五 绘制js组件
- React的CSS
- React Native SDK location not found
- 第一个React程序HelloWorld
- 谈谈react-router学习
- Android React Native安装指南
- 学习 React Native for Android:环境搭建
- 第三讲:React Native & HTML5+(学习笔记1)
- React Native 组件样式测试
- Android:React Native 随记
- React.js入门
- react-native中碰到的问题
- Reactor And Proactor
- reactjs前端开发
- 最快让你上手ReactiveCocoa之基础篇
- React 入门实例教程
- React Native 使用问题记录
- React-Native环境配置
- React-Native植入原声应用 - Android