React基础概念

Hello Wrold

ReactDOM.render(
<h1>Hello, world!</h1>,
document.getElementById('root')
);

通过react渲染一个Hello, world!

JSX

即不是字符串也不是HTML,而且是一种JS语法扩展

在JSX中可以使用表达式

function formatName(user) {
return user.firstName + ' ' + user.lastName;
} const user = {
firstName: 'Harper',
lastName: 'Perez'
}; const element = (
<h1>
Hello, {formatName(user)}!
</h1>
); ReactDOM.render(
element,
document.getElementById('root')
);

Babel会将JSX转换成React.createElement()的方法调用

const element = (
<h1 className="greeting">
Hello, world!
</h1>
);
const element = React.createElement(
'h1',
{className: 'greeting'},
'Hello, world!'
);

元素渲染

在React中元素事实上是普通的对象

将元素渲染到DOM节点中,需要将元素传递给ReacDOM.render()的方法来渲染到页面重

const element = <h1>Hello, world</h1>;
ReactDOM.render(element, document.getElementById('root'));

组件

组件可以将UI切个成独立的可复用的部件,组件从概念上来讲是函数

函数定义

function Welcome(props) {
return <h1>Hello, {props.name}</h1>;
}

类定义组件

class Welcome extends React.Component {
render() {
return <h1>Hello, {this.props.name}</h1>;
}
}

Props是只读属性

生命周期

setState

不能直接更改状态,因为不会重新渲染组件

this.state.comment = 'Hello';

使用setState

this.setState({comment: 'Hello'});

但是状态更新是异步的

React可能将多个setState合并成一个setState

第二种形式setState参数接收函数

this.setState((prevState, props) => ({
counter: prevState.counter + props.increment
}));

为了实现同步,我们可以使用Promise封装setState

事件处理

class Toggle extends React.Component {
constructor(props) {
super(props);
this.state = {isToggleOn: true}; // This binding is necessary to make `this` work in the callback
this.handleClick = this.handleClick.bind(this);
} handleClick() {
this.setState(prevState => ({
isToggleOn: !prevState.isToggleOn
}));
} render() {
return (
<button onClick={this.handleClick}>
{this.state.isToggleOn ? 'ON' : 'OFF'}
</button>
);
}
} ReactDOM.render(
<Toggle />,
document.getElementById('root')
);
class LoggingButton extends React.Component {
handleClick() {
console.log('this is:', this);
} render() {
// This syntax ensures `this` is bound within handleClick
return (
<button onClick={(e) => this.handleClick(e)}>
Click me
</button>
);
}
}
传递参数
class Popper extends React.Component{
constructor(){
super();
this.state = {name:'Hello world!'};
} preventPop(name, e){ //事件对象e要放在最后
e.preventDefault();
alert(name);
} render(){
return (
<div>
<p>hello</p>
{/* Pass params via bind() method. */}
<a href="https://reactjs.org" onClick={this.preventPop.bind(this,this.state.name)}>Click</a>
</div>
);
}
}

条件渲染

 if (isLoggedIn) {
button = <LogoutButton onClick={this.handleLogoutClick} />;
} else {
button = <LoginButton onClick={this.handleLoginClick} />;
}
上一篇:Vue基础01vue的基本示例,vue的双向数据绑定,vue中常见的几种用法,vue相关常见指令


下一篇:html验证码