一个简单的vue的todolist例子

使用Vue.js实现动态列表增删
本文介绍如何使用Vue.js框架创建一个可以动态添加和删除元素的列表应用。通过v-model指令双向绑定输入框与数据,点击按钮调用方法更新数据列表,实现了列表项的动态管理。
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="vue.js"></script>
	</head>
	<body>
		<div id="app">
			<input type="text" v-model="input" /><button type="button" @click="handleAdd">提交</button>
			<ul>
				<li v-for="(itm,ind) in list" :key="ind">{{itm.name}}<button @click="handelDel(ind)">删除</button></li>
			</ul>
		</div>
		<script>
			let app = new Vue({
				el: '#app',
				data: {
					input: '',
					list: [
						{
							id: 1,
							name: 'html'
						},
						{
							id: 2,
							name: 'css'
						},
						{
							id: 3,
							name: 'js'
						}
					]
				},
				methods:{
					handleAdd(){
						let params = {
							id: this.list.length,
							name: this.input
						}
						this.list.push(params)
						this.input = ""
					},
					handelDel(index){
						this.list.splice(index,1)
					}
				}
			})
		</script>
	</body>
</html>

 

要在Vue.js中创建一个简单的待办事项列表(TodoList),你可以遵循下面的步骤和基本组件结构。首先,你需要安装Vue CLI,然后创建一个新的项目。接下来,我们会创建一个`TodoItem.vue`组件表示单个待办事项以及一个`TodoList.vue`组件管理整个列表。 ### `TodoItem.vue`(单个待办事项组件) ```html <template> <li class="todo-item"> <input type="text" v-model="task" placeholder="添加任务..."> <button @click="deleteTask">删除</button> </li> </template> <script> export default { data() { return { task: '', }; }, methods: { deleteTask() { this.$emit('deleteTask', this.task); this.task = ''; }, }, }; </script> <style scoped> .todo-item { padding: 5px; } </style> ``` ### `TodoList.vue`(待办事项列表组件) ```html <template> <div class="todo-list"> <input type="text" v-model="newTask" placeholder="输入新任务..."> <button @click="addTask">添加</button> <ul> <li v-for="(task, index) in tasks" :key="index"> {{ task }} <button @click="deleteTask(index)">删除</button> </li> </ul> </div> </template> <script> import TodoItem from './TodoItem.vue'; export default { components: { TodoItem, }, data() { return { newTask: '', tasks: [], }; }, methods: { addTask() { this.tasks.push(this.newTask); this.newTask = ''; }, deleteTask(index) { this.tasks.splice(index, 1); }, }, }; </script> <style scoped> .todo-list { list-style-type: none; } </style> ``` 在这个例子中,`TodoItem`组件接受一个事件`deleteTask`来处理删除操作,`TodoList`组件维护着`tasks`数组,并通过`v-for`循环渲染每个待办事项。用户可以添加新的任务并清除已完成的任务。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LLL_LH

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值