網站首頁 編程語言 正文
react向數組中追加值
首先,渲染一個隨機數,每個一秒變換一次,效果如下:
代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>數組追加元素</title>
<script src="https://cdn.staticfile.org/react/16.4.0/umd/react.development.js"></script>
<script src="https://cdn.staticfile.org/react-dom/16.4.0/umd/react-dom.development.js"></script>
<script src="https://cdn.staticfile.org/babel-standalone/6.26.0/babel.min.js"></script>
</head>
<body>
<div id="xpf"></div>
<script type="text/babel">
class Xpf extends React.Component {
constructor(props){
super(props);
this.state = {
random:Math.random()
}
}
componentWillMount(){
setInterval(() => {
this.setState({
random:Math.random()
})
}, 1000);
}
render() {
let {random} = this.state;
return (
<div>
<div>
{random}
</div>
</div>
);
}
}
ReactDOM.render(
<Xpf />,
document.getElementById('xpf')
);
</script>
</body>
</html>
注意:組件更新有兩種方式:props或state的改變,而改變state一般是通過setState()方法來的,只有當state或props改變,render()方法才能再次調用,即組件更新
將生成的隨機數放入一個數組,效果如下:
代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>數組追加元素</title>
<script src="https://cdn.staticfile.org/react/16.4.0/umd/react.development.js"></script>
<script src="https://cdn.staticfile.org/react-dom/16.4.0/umd/react-dom.development.js"></script>
<script src="https://cdn.staticfile.org/babel-standalone/6.26.0/babel.min.js"></script>
</head>
<body>
<div id="xpf"></div>
<script type="text/babel">
class Xpf extends React.Component {
constructor(props){
super(props);
this.state = {
random:Math.random(),
arr:[1,2,3]
}
}
componentWillMount(){
setInterval(() => {
this.setState({
random:Math.random(),
arr:[...this.state.arr,Math.random()]
})
}, 1000);
}
render() {
let {random,arr} = this.state;
return (
<div>
<div>
{random}
</div>
<ul>
{
arr.map((item,index)=>{
return ( <li key={index}>{item}</li>)
})
}
</ul>
</div>
);
}
}
ReactDOM.render(
<Xpf />,
document.getElementById('xpf')
);
</script>
</body>
</html>
使用...this.state.arr將arr解構出來,在將隨機數加進去
注意:不能使用 arr : this.state.arr.push(Math.random()),不能使用在原數組的基礎上修改的方法,例如push之類,可以使用concat方法或者ES6數組拓展語法
react處理數組的值
1. 追加數組的值
通過…運算符把數組之前的值拆分,再在后面追加值
this.state = {
? arr: []
}
add(){
? this.setState((prevSatet) => ({
? ? arr: [...prevSatet.arr, [追加的值] ]
? }))
}
2. 刪除下標為index的值
把state中arr的值拷貝到新的arr中,刪除新arr下標為index的值后,再重新賦值回arr
主要不要直接刪除state中arr的值,然后賦值回去,這樣違反immutable的規則
this.state = {
? arr: []
}
delete(index){?
? this.setState((prevState) => {
? ? const arr = [...prevState.list]
? ? arr.splice(index, 1)
? ? return { arr }
? })
}
原文鏈接:https://blog.csdn.net/qq_42720683/article/details/95594398
相關推薦
- 2022-02-24 將antd中的Tree組件放在Form表單里面
- 2022-03-14 跨域問題Response to preflight request doesn't pass acc
- 2022-05-04 python?與c++相互調用實現_python
- 2022-06-02 關于Python使用turtle庫畫任意圖的問題_python
- 2022-08-20 Go?多環境下配置管理方案(多種方案)_Golang
- 2022-04-12 ASP動態include文件_ASP基礎
- 2023-07-02 Oracle中分析函數over()的用法及說明_oracle
- 2022-09-12 ios開發UITableViewCell圖片加載優化詳解_IOS
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支