react组件的 render 方法

一个组件类必须要实现一个 render 方法,
这个 render 方法必须要返回一个 JSX 元素。
必须要用一个外层的 JSX 元素把所有内容包裹起来,返回并列多个 JSX 元素是不合法的.

错误的写法:

render () {
return (
<div>第一个</div>
<div>第二个</div>
)
}
正确的写法:

render () {
return (
<div>
<div>第一个</div>
<div>第二个</div>
</div>
)
}
表达式插入

在 JSX 当中你可以插入 JavaScript 的表达式,表达式返回的结果会相应地渲染到页面上。
要求: 表达式用 {} 包裹。
render () {
const word = 'is good'
return (
<div>
<h1>React 小书 {word}</h1>
</div>
)
}
可以用函数表达式来返回:
render () {
return (
<div>
<h1>React 小书 {(function () { return 'is good'})()}</h1>
</div>
)
}
{} 内可以放任何JavaScript代码。render都会把这些代码返回的内容如实渲染在页面上。

{}还可以用在标签的属性上. eg:

render () {
const className = 'header'
return (
<div className={className}>
<h1>React 小书</h1>
</div>
)
}
直接使用 class 在 React.js 的元素上添加类名如<div class=“xxx”> 这种方式是不合法的。
还有一个特例就是 for 属性,例如<label for='male'>Male</label>,因为 for 也是 JavaScript 的关键字,所以在 JSX 用 htmlFor 替代,即 <label htmlFor='male'>Male</label>.

条件返回

render () {
const isGoodWord = true
return (
<div>
<h1>
React 小书
{isGoodWord
? <strong> is good</strong>
: <span> is not good</span>
}
</h1>
</div>
)
}
上面的代码中定义了一个 isGoodWord 变量为 true,下面有个用 {} 包含的表达式,根据 isGoodWord 的不同返回不同的 JSX 内容。

如果返回 null ,那么 React.js 会什么都不显示,相当于忽略了该表达式插入。

render () {
const isGoodWord = true
return (
<div>
<h1>
React 小书
{isGoodWord
? <strong> is good</strong>
: null
}
</h1>
</div>
)
}
JSX 元素变量

render () {
const isGoodWord = true
const goodWord = <strong> is good</strong>
const badWord = <span> is not good</span>
return (
<div>
<h1>
React 小书
{isGoodWord ? goodWord : badWord}
</h1>
</div>
)
}
这里给把两个 JSX 元素赋值给了 goodWord 和 badWord 两个变量,然后把它们作为表达式插入的条件返回值。达到效果和上面的例子一样,随机返回不同的页面效果呈现。

renderGoodWord (goodWord, badWord) {
const isGoodWord = true
return isGoodWord ? goodWord : badWord
}

render () {
return (
<div>
<h1>
React 小书
{this.renderGoodWord(
<strong> is good</strong>,
<span> is not good</span>
)}
</h1>
</div>
)
}
定义了一个 renderGoodWord 函数,这个函数接受两个 JSX 元素作为参数,并且随机返回其中一个。在 render 方法中,我们把上面例子的两个 JSX 元素传入 renderGoodWord 当中,通过表达式插入把该函数返回的 JSX 元素插入到页面上。

作者:咸鱼小N
链接://www.greatytc.com/p/83607f37ccaf
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • React.js 小书 Lesson7 - 组件的 render 方法 本文作者:胡子大哈本文原文:http://...
    胡子大哈阅读 437评论 0 0
  • 深入JSX date:20170412笔记原文其实JSX是React.createElement(componen...
    gaoer1938阅读 8,116评论 2 35
  • react 基本概念解析 react 的组件声明周期 react 高阶组件,context, redux 等高级...
    南航阅读 1,097评论 0 1
  • 以下内容是我在学习和研究React时,对React的特性、重点和注意事项的提取、精练和总结,可以做为React特性...
    科研者阅读 8,308评论 2 21
  • 许愿的孩童已长大,许下的愿是否长大? 当我们还是稚童的时候,爸爸妈妈就会玩笑式地问我们,以后长大了要做什么。他们那...
    许一树梦话阅读 396评论 0 1