JSX基础
1. JSX基础
概念
: JSX是 JavaScript XML(HTML)的缩写,表示在 JS 代码中书写 HTML 结构
作用
:在React中创建HTML结构(页面UI结构
优势
:
- 采用类似于HTML的语法,降低学习成本,会HTML就会JSX
- 充分利用JS自身的可编程能力创建HTML结构
注意
:JSX 并不是标准的 JS 语法,是 JS 的语法扩展,浏览器默认是不识别的,脚手架中内置的 @babel/plugin-transform-react-jsx
包,用来解析该语法
2. JSX中使用js表达式
语法
: { JS 表达式 }
const name = 'zjj';
<h1>你好,我叫{name}</h1> // <h1>你好,我叫zjj</h1>
可以使用的表达式
- 字符串、数值、布尔值、null、undefined、object( [] / {} )
- 1 + 2、'abc'.split('')、['a', 'b'].join('-')
- fn()
特别注意
if 语句/ switch-case 语句/ 变量声明语句,这些叫做语句,不是表达式,不能出现在 {} 中!!
3. JSX列表渲染
实现
:使用数组的map 方法
// 来个列表
const songs = [
{ id: 1, name: '痴心绝对' },
{ id: 2, name: '像我这样的人' },
{ id: 3, name: '南山南' }
];
function App() {
return (
<div className="App">
<ul>
{
songs.map(item => <li key={item.id}>{item.name}</li>)
}
</ul>
</div>
);
}
export default App;
4. JSX条件渲染
作用
:根据是否满足条件生成HTML结构,比如Loading效果
实现
:可以使用 三元运算符 或 逻辑与(&&)运算符
// 来个布尔值
const flag = true;
function App() {
return (
<div className="App">
{/* 条件渲染字符串 */}
{flag ? 'react真有趣' : 'vue真有趣'}
{/* 条件渲染标签/组件 */}
{flag ? <span>this is span</span> : null}
</div>
)
}
export default App;
5. JSX样式处理
- 行内样式 - style
function App() {
return (
<div className="App">
<div style={{ color: 'red' }}>this is a div</div>
</div>
)
}
export default App;
- 行内样式 - style - 更优写法
const styleObj = {
color: red
};
function App() {
return (
<div className="App">
<div style={styleObj}>this is a div</div>
</div>
)
}
export default App;
- 类名 - className(推荐)
.title {
font-size: 30px;
color: blue;
}
- 类名 - className - 动态类名控制
import './app.css';
const showTitle = true;
function App() {
return (
<div className="App">
<div className={showTitle ? 'title' : ''}>this is a div</div>
</div>
)
}
export default App;
6. JSX注意事项
- JSX必须有一个根节点,如果没有根节点,可以使用<></>(幽灵节点)替代
- 所有标签必须形成闭合,成对闭合或者自闭合都可以
- JSX中的语法更加贴近JS语法,属性名采用驼峰命名法 class -> className for -> htmlFor
- JSX支持多行(换行),如果需要换行,需使用() 包裹,防止bug出现