提交 d23d63a9 编写于 作者: Z zhaoshuangshi

3.2.1小节习题、关键字

上级 5f72eb43
{
"type": "code_options",
"author": null,
"source": "exercises.md",
"notebook_enable": false,
"exercise_id": "c39802e0a80948a5b6225ac98fa33dcd"
}
\ No newline at end of file
# JSX
<div style="color: pink;font-size:22px;font-weight:700">小常识:</div>
<br><br>
如果你写了很多 render 函数,可能会觉得下面这样的代码写起来很痛苦:
<br><br>
```javascript
createElement(
'anchored-heading', {
props: {
level: 1
}
}, [
createElement('span', 'Hello'),
' world!'
]
)
```
<br><br>
特别是对应的模板如此简单的情况下:
<br><br>
```javascript
<anchored-heading :level="1">
<span>Hello</span> world!
</anchored-heading>
```
<br><br>
这就是为什么会有一个 Babel 插件,用于在 Vue 中使用 JSX 语法,它可以让我们回到更接近于模板的语法上。
<br><br>
```javascript
import AnchoredHeading from './AnchoredHeading.vue'
new Vue({
el: '#demo',
render: function (h) {
return (
<AnchoredHeading level={1}>
<span>Hello</span> world!
</AnchoredHeading>
)
}
})
```
<br><br>
将 h 作为 createElement 的别名是 Vue 生态系统中的一个通用惯例,实际上也是 JSX 所要求的。从 Vue 的 Babel 插件的 3.4.0 版本开始,我们会在以 ES2015 语法声明的含有 JSX 的任何方法和 getter 中 (不是函数或箭头函数中) 自动注入 const h = this.$createElement,这样你就可以去掉 (h) 参数了。对于更早版本的插件,如果 h 在当前作用域中不可用,应用会抛错。
<br><br>
<div style="color: #8E7CC3;font-size:22px;font-weight:700">小测试:</div>
以下对jsX的描述不正确的是? <br/><br/>
## 答案
在编译之后, jsX会被转化为普通的Javascript对象,不可以在if或者for语句里使用JSX
## 选项
### A
全称是Javascript XML
### B
JSX是一种JavaScript的语法扩展
### C
JSX可以使用引号来定义以字符串为值的属性
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册