夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

时间:2025-01-15 11:37:56

在很多前端框架中todos都是一个小的参考例子,在react中当然也是不例外的,先来看看最终的效果先。。。

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

这个就是官方的例子,我们先来分析下他是由那及格组建组合成的。。。

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

再来分析下他是的数据最终是由那些地方过来的。。。

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

由于我们在react里面传递的参数都是不能跨级传递的,都是通过一级级往下传递的,如下图所示:

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

然后再Ul组建里面用props来进行传递,因为是数组我们可以使用数组的方式进行传递。。

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

但是这种方式只要懂得编程的朋友们应该都知道是不科学的,当然react也不列外,他给我们开发者预留了map方法来进行数据遍历

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

然后在对数据进行输出:

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

效果好像出现了。。。

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

在分析下原理...

夺命雷公狗-----React---22--小案例之react经典案例todos(完成数据的遍历)

首先用getInitialState来对属性进行模拟,

然后在Zong组建里面用<Ul todos={this.state.todos} /> 对她进行传递到ul里面,

然后在Ul里面用map方法对数据进行传递到li里面,

然后在li里面通过{this.props.todo.text}进行取出

上面图片的代码只是伪代码,可以能有个别地方没修正,测试代码如下所示:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script src="./js/react.js"></script>
<script src="./js/react-dom.js"></script>
<script src="./js/browser.min.js"></script>
</head>
<body>
<div id="dome"></div>
<script type="text/babel">
//搜索区域
var Ck = React.createClass({
render:function(){
return(
<div>
<input type="text" placeholder="你要干嘛?" />
</div>
);
}
});
//列表项区域
var Lists = React.createClass({
render:function(){
return(
<li>
<label>
<input type="checkbox" checked={this.props.todo.isDown} />
{this.props.todo.text}
</label>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<button>删除</button>
</li>
);
}
});
//列表框区域
var Ul = React.createClass({
render:function(){
return(
<ul>
{
this.props.todos.map(function(item,index){
return <Lists todo={item} key={index} />
})
}
</ul>
);
}
});
//状态组建
var Status = React.createClass({
render:function(){
return(
<div>
<input type="checkbox" />
3 已完成 / 3 总数
&nbsp;&nbsp;&nbsp;
<button>清除已完成</button>
</div>
);
}
});
//总组建
var Zong = React.createClass({
getInitialState:function(){
return {
todos :[
{text:'6点起床',isDown:true},
{text:'7点出门',isDown:true},
{text:'8点吃早饭',isDown:false},
{text:'9点上班',isDown:true},
{text:'12点下班',isDown:false}
],
isAllChecked: false
}
},
render:function(){
return(
<div>
<Ck />
<Ul todos={this.state.todos} />
<Status />
</div>
);
}
});
ReactDOM.render(
<Zong />,
document.getElementById('dome')
);
</script>
</body>
</html>