React更新元素 基础

React元素创建后无法修改其内容和属性。唯一的办法是创建新的元素,传入ReactDOM.render()方法

三种实现形式:

1.整体替换

function tick () {
  const ele=(
    <div>
      <h1>更新元素</h1>
      <h2>现在是:{new Date().toLocaleTimeString()}</h2>  
    </div>)  ;
  ReactDOM.render(
    ele,
    document.getElementById('example')
  )
}
setInterval(tick,1000);

2.将要展示的部分封装起来

function Clocks (props) {
  return (
    <div>
      <h1>Hello,world</h1>
      <h2>现在是{props.date.toLocaleString()}</h2>
    </div>
  )
}
function tick () {
  ReactDOM.render(
    <Clock date={new Date()}>,
    document.getElementById('example')
  )
}
setInterval(tick,1000)

解析:每隔1秒执行tick  触发Clock 将参数传递到Clock函数中,修改html

3.创建React.Component的类,封装要显示的元素

class Clock extends React.Component{
  render(){
    return (
      <div>
        <h1>Hello world</h1>
        <h2>现在是{this.props.date}</h2>
      </div>
    )
  }
}
function tick (){
  ReactDOM.render(
    <Clock date={new Date()}/>,
    document.getElementById('example')
  )
}
setInterval(tick,1000)

React会对比元素内容的先后不同,渲染的时候只更新不同的部分

转载于:https://www.cnblogs.com/shui1993/p/9958219.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值