<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>todolist</title>
<script src="./src/assets/js/vue.js"></script>
<style>
.done{/*待办事项完成与否的样式*/
text-decoration: line-through;/*加入横穿文字的直线*/
background-color: red;
}
</style>
</head>
<body>
<h2>待办事项</h2>
<div id="app">
<input type="text" v-model="content"/><button @click="addTask">添加任务</button><!--代办事项的输入框-->
<ul>
<li v-for="task,index in list" :key="index"><!--利用v-for完成待办事项的循环展示-->
<span :class="{'done':task.isDone}">{{task.name}}<!--利用span把代办事项的内容包裹起来,样式展示利用:class来实现-->
</span><button @click="maskDone(task)">标记已完成</button><!--添加标记已完成的按钮-->
<button @click="deleteTask(index)">删除待办事项</button><!--添加删除代办事项的按钮-->
</li>
</ul>
</div>
<script>
var vm = new Vue({
el:"#app",
data:{
list:[]
},
methods:{
addTask(){
if(this.content!==''||this.content.length!==0){
let task = {/*创建一个对象,并存入list数组*/
'name':this.content,
'isDone':false
}
this.list.push(task);
this.content = ''/*最后把输入框的内容置为空*/
}
},
deleteTask(index){
this.list.splice(index,1)
},
maskDone(task){
task.isDone = true
}
}
})
</script>
</body>
</html>
vue.js实现简单的待办事项小demo
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...