在搭建后的react环境下进入src/index.js文件中写业务:
1.引入react & react-dom两个包
data:image/s3,"s3://crabby-images/1ef27/1ef2707658a495a729aa1fad938697d45c2c116c" alt="2018-09-18 react学习(二):props & state"
通过console.log我们发现reactdome自带了一个renderAPI,我们可以通过该api来传递并渲染:
语法:
ReactDom.render(jsx元素,注入点,回调)
eg:
data:image/s3,"s3://crabby-images/854a1/854a1f580a02d2e6c83c5bf7403d6d6a6fa99d21" alt="2018-09-18 react学习(二):props & state"
效果如下:
data:image/s3,"s3://crabby-images/a69fd/a69fd8d660367011f8c4703269e6ae867386c639" alt="2018-09-18 react学习(二):props & state"
添加多个元素语法(一定要有根元素包裹,不然报错):
data:image/s3,"s3://crabby-images/4c90e/4c90e626d307d9a49cb9f22ba0b970426beaaf7f" alt="2018-09-18 react学习(二):props & state"
组件
react创建组件其实就是创建一个普通的类,但是必须要有继承。
语法:
class 组件名 extends React.Component{
constrctor(props){
super(props)
this.state={
本地状态}}
render(){
returen html/jsx
}
render -专门负责渲染render函数的UI,当别人试用这个组件的时候,render在虚拟dom中渲染
真实dom的渲染只有可能出现在reactdom,它是 浏览器主入口
tips:组件变量名和组件名首字母大写
eg:
tips:一定要有render和return
data:image/s3,"s3://crabby-images/e718b/e718bf45510bf5134451beaca36dec64ae3f2126" alt="2018-09-18 react学习(二):props & state"
or
data:image/s3,"s3://crabby-images/938c6/938c6119edd7adb097ac2170a568ff0b0593e3f5" alt="2018-09-18 react学习(二):props & state"
效果:
data:image/s3,"s3://crabby-images/98281/98281602dce9e331c96ab1002c25b39cfd5b67f1" alt="2018-09-18 react学习(二):props & state"
组件嵌套:
import React from ‘react’;
import ReactDom from ‘react-dom’;
let ele=<div>hello</div>;
class App extends React.Component{
render(){
return (<div>
<Header></Header>
<Wrap></Wrap>
<Footer></Footer>
</div>); }}
class Header extends React.Component{
render(){return (<div>这是header组件</div>)}}
class Wrap extends React.Component{
render(){return (<div>这是wrap组件</div>)}}
class Footer extends React.Component{
render() {return (<div>这是footer组件</div>); }}
ReactDom.render(
<App></App>,
document.querySelector(‘#root’));
效果:
data:image/s3,"s3://crabby-images/a7510/a7510015cb2e0a585978e00132f3009aba0e6467" alt="2018-09-18 react学习(二):props & state"
props:
tips: json数据的传递
data:image/s3,"s3://crabby-images/4da6c/4da6cfaf43c0611a3c900628a5a6fd0793feddd1" alt="2018-09-18 react学习(二):props & state"
效果:
data:image/s3,"s3://crabby-images/cbd61/cbd6123ed67e7705844dd40213e1ce17e1f6c23f" alt="2018-09-18 react学习(二):props & state"
state:
es6
data:image/s3,"s3://crabby-images/0d9aa/0d9aa7904ffb9ca878cd88b5bff453ef1f12b749" alt="2018-09-18 react学习(二):props & state"
效果:
data:image/s3,"s3://crabby-images/06961/06961f27f18e813733a750202b8ce5583b5a41a3" alt="2018-09-18 react学习(二):props & state"
es7(不需要构造器)
data:image/s3,"s3://crabby-images/6f0b1/6f0b14f37aa52e3ef50b6a0fb05e5e1a2a5541a9" alt="2018-09-18 react学习(二):props & state"
state 特殊数据类型
tips:《转义输出》
<div dangerouslySetInnerHTML={{__html:this.state.strong}}> </div>
import React from ‘react’;
import ReactDom from ‘react-dom’;
class App extends React.Component{
state={
msg:”ok”,
strong:'<strong>加粗</strong>’ };
render(){
return (
<div>
<h3>{this.props.title}</h3>
<div dangerouslySetInnerHTML={{__html:this.state.strong}}>
</div>
</div>); }}
ReactDom.render(
<App/>,
document.querySelector(‘#root’));
效果:
data:image/s3,"s3://crabby-images/c5fb6/c5fb637ef32755ab85ca816ecd9dd255a9ee4019" alt="2018-09-18 react学习(二):props & state"
定义实例方法:
data:image/s3,"s3://crabby-images/7bdfd/7bdfd430b550c086fd17b31276b3cf698a17f2e2" alt="2018-09-18 react学习(二):props & state"
data:image/s3,"s3://crabby-images/e5387/e5387445e03ad392e1dc91b09b8228c09c7ec517" alt="2018-09-18 react学习(二):props & state"