npm i -S babel-standalone react react-dom
//寫react語法 須要babel解析
<script src="node_modules/babel-standalone/babel.js"></script>
//react框架 實現 ui 用戶界面 只關注ui層
<script src="node_modules/react/umd/react.development.js"></script>
//react-dom 用戶交互 只處理dom
<script src="node_modules/react-dom/umd/react-dom.development.js"></script>
複製代碼
babel 解析器: 框架的代碼想要瀏覽端預覽 須要進行轉換,轉換瀏覽器 認識的語言前端
ReactDOM.render(element, container, callback);node
<div id="app"></div>
react
demo1npm
ReactDOM.render(
<h1>Hello World</h1>,
document.querySelector('#app')
)
複製代碼
demo2數組
const element2 = <h1>
<span>Hello World</span>
<span>Hello React</span>
</h1>;
ReactDOM.render(
element2,
document.querySelector('#app')
)
複製代碼
demo3瀏覽器
function createJSX (){
return (
<h1>
<span>Hello World</span>
<span>Hello React</span>
</h1>
)
}
const element3 = createJSX()
ReactDOM.render(
element3,
document.querySelector('#app')
)
複製代碼
使用{}插入數據,括號中爲js代碼bash
demo1 使用{}插入數據babel
const person = {
name: 'sjl',
age: 18,
sex: 0
};
const element1 = (
<div>
<h1> Hello World </h1>
<h2> 名字: {person.name} </h2>
<h2> 年齡: {person.age} </h2>
</div>
);
ReactDOM.render(
element1,
document.querySelector('#app')
);
複製代碼
demo2 循環mapapp
const arr = ['張三','李四','王二','狗蛋','大錘'];
const element2 = (
<div>
<ul>
{
arr.length >0 && arr.map((item,index)=>{
// li標籤的是屬性綁定
return (
<li key={index}>{item}</li>
// key屬性至關於身份證id,惟一性
)
})
}
</ul>
</div>
);
ReactDOM.render(
element2,
document.querySelector('#app')
);
複製代碼
demo3 三目運算判斷
後臺經過傳輸0,1數據,前端經過該數據判斷結果,以性別男女爲例框架
const person = {
name: 'sjl',
age: 18,
sex: 0
};
const element3 = (
<div>
<h2>
性別:
{
// 不能寫if判斷 只是表達式
person.sex ? '女': '男'
}
</h2>
</div>
);
ReactDOM.render(
element3,
document.querySelector('#app')
);
複製代碼
當sex爲0時,性別爲男;當sex爲1時,性別爲女
demo4 利用函數同理demo3
const person = {
name: 'sjl',
age: 18,
sex: 0
};
const element4 = (
<div>
{
(function () {
if( person.sex ) return <h2>女</h2>;
return <h2>男</h2>
})()
}
</div>
);
ReactDOM.render(
element4,
document.querySelector('#app')
);
複製代碼
demo5 展開數組和對象(對象須要stringify,不能自動展開)
const person = {
name: 'sjl',
age: 18,
sex: "男"
};
const arr = ['張三','李四','王二','狗蛋','大錘'];
const element5 = (
<div>
<p>{arr}</p>
<p>{JSON.stringify(person)}</p>
</div>
);
ReactDOM.render(
element5,
document.querySelector('#app')
);
複製代碼
注:在react中,用className代替class;
input標籤中的value用defaultValue代替,能夠修改值。
demo1
const person = {
name: 'sjl',
age: 18,
sex: "男"
};
const styles = {
name:{
backgroundColor: "#f66",
color: "#fff"
},
age:{
fontSize: '50px',
color: 'skyblue'
}
};
const element1 = (
<div>
<h1 style={{color:'hotpink'}}> Hello World </h1>
<h2 style={styles.name}> 名字: {person.name} </h2>
<h2 style={styles.age}> 年齡: {person.age} </h2>
</div>
);
ReactDOM.render(
element1,
document.querySelector('#app')
);
複製代碼