这一个其实是比较容易的,只需要统计他的总数和已完成的即可,

效果如下所示:

代码如下所示:

<!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({
//处理搜索事件的函数
handleKey:function(e){
//alert('test');
//判断回车enter键才处理,keyCode13==回车键
if(e.keyCode == 13){
//alert('test');
//如果搜索内容是空的让他不走了
if(!e.target.value) return;
//否则添加任务了
var ckcon = {
text : e.target.value,
isDown: false
}
//利用属性完成
this.props.addCkcon(ckcon);
//清空搜索框的内容
e.target.value = '';
} },
render:function(){
return(
<div>
<input type="text" placeholder="你要干嘛?" onKeyUp={this.handleKey} />
</div>
);
}
});
//列表项区域
var Lists = React.createClass({
handleClick:function(){
//alert('test');
this.props.deleteCkcon(this.props.index);
},
//处理单选框的变化事件
handleChange:function(e){
//修改那个任务,修改的值是什么
this.props.changeStatus(this.props.index,e.target.checked);
},
render:function(){
return(
<li>
<label>
<input type="checkbox" checked={this.props.todo.isDown} onChange={this.handleChange} />
{this.props.todo.text}
</label>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<button onClick={this.handleClick}>删除</button>
</li>
);
}
});
//列表框区域
var Ul = React.createClass({
render:function(){
//保存this指针
var _this = this;
return(
<ul>
{
this.props.todos.map(function(item,index){
return <Lists todo={item} key={index} index={index} deleteCkcon={_this.props.deleteCkcon} changeStatus={_this.props.changeStatus} />
})
}
</ul>
);
}
});
//状态组建
var Status = React.createClass({
render:function(){
return(
<div>
<input type="checkbox" />
{this.props.countDown} 已完成 / {this.props.total} 总数
&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
}
},
addCkcon:function(todo){
//接收到用户的添加的内容然后铺push过去即可
this.state.todos.push(todo);
//然后更新state
this.setState({
todos : this.state.todos
});
},
//处理删除任务
deleteCkcon:function(index){
//用函数splice来删除掉指定的数组元素
this.state.todos.splice(index,1);
//删除完成后来更新下页面的内容
this.setState({
todos : this.state.todos
});
},
//任务单选框的属性
changeStatus:function(index,isDown){
this.state.todos[index].isDown = isDown
this.setState({
todos : this.state.todos
})
},
//统计总的任务个数
total:function(){
return this.state.todos.length || 0
},
//统计已完成的
countDown:function(){
var arr = this.state.todos.filter(function(todo){
return todo.isDown
});
return arr.length || 0;
},
render:function(){
return(
<div>
<Ck addCkcon={this.addCkcon} />
<Ul todos={this.state.todos} deleteCkcon={this.deleteCkcon} changeStatus={this.changeStatus} />
<Status total={this.total()} countDown={this.countDown()} />
</div>
);
}
});
ReactDOM.render(
<Zong />,
document.getElementById('dome')
);
</script>
</body>
</html>

最新文章

  1. Java中的反射机制
  2. Ubuntu安装uget和aria2下载工具
  3. 自编基于jQuery实现分页插件
  4. svn认证失败时的解决
  5. java使用jsp servlet来防止csrf 攻击的实现方法
  6. Android 在onActivityResult()中设置图片setImageResource(resId) 或者改变view属性,不成功的解决办法
  7. js按钮点击展开收起
  8. input元素有padding间距,所以使用box-sizing来保持宽度不超出父元素
  9. gap锁 对于unique index 和Ununique index
  10. JSONArray用法jquery循环list&lt;Map&gt;对象
  11. 表达式求值(二叉树方法/C++语言描述)(二)
  12. Docker mysql主主互备和高可用
  13. jquery之data()
  14. 帝国cms文章页调用当前文章URL如何操作?
  15. PGSQL 数据库备份练习
  16. 淘宝商品放大镜效果-JavaScript
  17. webPage logService 日志服务 剥离
  18. 全新的css网站布局--Grid布局
  19. C#中的Stack的Peek操作,曝出异常
  20. jQuery九宫格图片拉伸变大代码

热门文章

  1. SRM 618 DIV1 500
  2. Django分析之三级下拉菜单选择省/市/县
  3. js 闭包之一
  4. centos使用yum安装软件的时候出现了undefined symbol: CRYPTO_set_locking_callback
  5. bzoj2500: 幸福的道路(树形dp+单调队列)
  6. Android四大组件--ContentProvider详解(转)
  7. HDU 4757 Tree(可持久化Trie+Tarjan离线LCA)
  8. JS脚本收藏(一些实用的函数)
  9. javascript立即执行函数
  10. LoadRunner - 001