2.6 KiB
2.6 KiB
createElement
劣势
- 繁琐不简洁
- 不直观,不能一眼看出代码表述
- 不优雅,用户体验差
jsx
语法与html类似 JSX 是JavaScript XML的简写,表示在JavaScript代码中写xml(html)格式的代码.React的核心内容 优势:声明式语法更加直观,与html结构相同,降低成本,提高开发效率 React完全利用js语言自身能力来编写UI,而不是造轮子增强HTML功能(没有自定义指令).
import React from 'react';
import ReactDOM from 'react-dom';
// const title = React.createElement('p',{title:"我是段落",id:"p1"},'hello xian',React.createElement('span',null,'hello hua'))
// jsx
const title = <p title='我是段落' id='p1'>hello xian<span>hello hua</span></p>
ReactDOM.render(title,document.getElementById('root'))
脚手架中使用jsx语法
- JSX不是标准的ECMAScript语法,是他的拓展
- 需要使用babel(@babel/preset-react)编译后,才能在浏览器中使用
- create-react-app脚手架中已经默认有了该配置无需配置.
基本用法
- 使用驼峰命名规则
- 特殊的属性名 class->className,for->htmlFor,tabindex->tabIndex
- 没有子节点可以使用/结尾
- 推荐在小括号内写JSX
const title = (<p className='title' title='我是段落' id='p1'>hello xian<span>hello hua</span></p>)
嵌入js
{JavaScript表达式}
const name = "----------------------------"
const title = (<p className='title' title='我是段落' id='p1'>hello xian {name}<span>hello hua</span></p>)
jsx条件渲染
根据条件渲染特定的jsx结构 if else ,三目,逻辑与运算符
const isLoading = false
const loadData= ()=>{
// if(isLoading){
// return <div>loading...</div>
// }
// return <div>数据加载完成,此处显示加载后的数据</div>
// return isLoading?(<div>loading...</div>):(<div>数据加载完成,此处显示加载后的数据</div>)
return isLoading && (<div>loading...</div>)
}
const title = (
<h1>
条件渲染{loadData()}
</h1>
)
jsx 列表渲染
const songs = [
{id:1,name:'有为歌'},
{id:2,name:'水手'},
{id:3,name:'都是月亮惹的祸'}
]
const list = (
<ul>
{songs.map(item=><li key={item.id}>{item.name}</li>)}
</ul>
)
ReactDOM.render(list,document.getElementById('root'))
jsx的样式处理
行内样式 style
const listStyle = (
<h1 style={{color:'red',backgroundColor:'skyblue'}}>行内样式</h1>
<h1 className = "title">类样式</h1>
)
类名 className
import './index.css'
const listStyle = (
<h1 className = "title">类样式</h1>
)
css
.title{
text-align: center;
}