TodoList 案例(Vue3): 使用Composition API

🤍 前端开发工程师、技术日更博主、已过CET6

🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1

🕠 牛客 高级专题作者、打造专栏《前端面试必备》《2024面试高频手撕题》《前端求职突破计划》

🍚 蓝桥云课 签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》《带你从入门到实战全面掌握 uni-app》

文章目录

以下是一个简单的TodoList案例,展示了如何在Vue3中使用Composition API来实现一个基本的待办事项列表。

项目结构

复制代码
src/
|-- components/
|   |-- TodoList.vue
|   |-- TodoItem.vue
|-- App.vue
|-- main.js
|-- store.js (使用Vuex)

TodoList.vue

html 复制代码
<template>
<div>
<h1>Todo List</h1>
<input v-model="newTodo" @keyup.enter="addTodo" placeholder="Add a new todo">
<ul>
<TodoItem
v-for="(todo, index) in todos"
:key="index"
:todo="todo"
@delete="deleteTodo(index)"
/>
</ul>
</div>
</template>

<script>
import { ref } from 'vue';
import TodoItem from './TodoItem.vue';

export default {
components: {
TodoItem
},
setup() {
const newTodo = ref('');
const todos = ref([]);

const addTodo = () => {
if (newTodo.value.trim()) {
todos.value.push({ text: newTodo.value.trim(), done: false });
newTodo.value = '';
}
};

const deleteTodo = (index) => {
todos.value.splice(index, 1);
};

return {
newTodo,
todos,
addTodo,
deleteTodo
};
}
};
</script>

TodoItem.vue

html 复制代码
<template>
<li>
<span :class="{ done: todo.done }">{{ todo.text }}</span>
<button @click="$emit('delete')">Delete</button>
</li>
</template>

<script>
export default {
props: {
todo: Object
}
};
</script>

<style>
.done {
text-decoration: line-through;
}
</style>

App.vue

html 复制代码
<template>
<TodoList />
</template>

<script>
import TodoList from './components/TodoList.vue';

export default {
components: {
TodoList
}
};
</script>

main.js

javascript 复制代码
import { createApp } from 'vue';
import App from './App.vue';
import store from './store'; // 如果使用Vuex

const app = createApp(App);
app.use(store); // 如果使用Vuex
app.mount('#app');

store.js (可选)

如果你想使用Vuex来管理状态,可以创建一个store.js文件:

javascript 复制代码
import { createStore } from 'vuex';

export default createStore({
state: {
todos: []
},
mutations: {
addTodo(state, todo) {
state.todos.push(todo);
},
deleteTodo(state, index) {
state.todos.splice(index, 1);
}
},
actions: {
// 可以在这里添加异步操作
}
});

然后在 main.js 中引入并使用这个store。

总结

以上代码展示了一个简单的TodoList应用,使用了Vue3的Composition API。在这个案例中,我们创建了两个组件:TodoListTodoItemTodoList 组件负责管理待办事项的添加和删除,而 TodoItem 组件负责显示单个待办事项。这个例子没有使用Vuex,但是你可以很容易地将其集成到Vuex store中,以便更好地管理状态。

相关推荐
人工智能训练4 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
会跑的葫芦怪5 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
xiaoqi9226 小时前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233226 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头88218 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas1368 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠8 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
2601_949833398 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
珑墨8 小时前
【Turbo】使用介绍
前端
军军君019 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three