使用 Vue 3 + TypeScript + Pinia 的简单项目

admin11个月前 (03-19)it知识853

以下是一个使用 Vue 3 + TypeScript + Pinia 的简单项目示例,我们将创建一个待办事项(Todo List)应用:

1. 创建项目

bashnpm create vue@latest# 选择 TypeScript 和 Pinia 选项cd your-projectnpm installnpm install pinia @pinia/nuxt

2. 项目结构

/src

  /stores

    todoStore.ts

  /components

    TodoList.vue

  App.vue

  main.ts

3. 创建 Pinia Store (/stores/todoStore.ts)

import { defineStore } from 'pinia'export interface Todo {  id: number  text: string  done: boolean}export const useTodoStore = defineStore('todo', {  state: () => ({    todos: [] as Todo[],    filter: 'all' as 'all' | 'done' | 'undone'  }),  actions: {    addTodo(text: string) {      this.todos.push({        id: Date.now(),        text,        done: false      })    },    toggleTodo(id: number) {      const todo = this.todos.find(t => t.id === id)      if (todo) {        todo.done = !todo.done      }    },    deleteTodo(id: number) {      this.todos = this.todos.filter(t => t.id !== id)    }  },  getters: {    filteredTodos(): Todo[] {      switch (this.filter) {        case 'done':          return this.todos.filter(t => t.done)        case 'undone':          return this.todos.filter(t => !t.done)        default:          return this.todos      }    }  }})


4. 主组件 (App.vue)

<script setup>import TodoList from './components/TodoList.vue'</script><template>  <div>    <h1>Todo List</h1>    <TodoList />  </div></template><style>.container {  max-width: 600px;  margin: 0 auto;  padding: 20px;}</style>

5. TodoList 组件 (/components/TodoList.vue)

<script setup>import { ref } from 'vue'import { useTodoStore } from '../stores/todoStore'import { storeToRefs } from 'pinia'const store = useTodoStore()const { filteredTodos: todos, filter } = storeToRefs(store)const { addTodo, toggleTodo, deleteTodo } = storeconst newTodo = ref('')const handleAdd = () => {  if (newTodo.value.trim()) {    addTodo(newTodo.value.trim())    newTodo.value = ''  }}</script><template>  <div>    <div>      <input        v-model="newTodo"        @keyup.enter="handleAdd"        placeholder="Add new todo..."      />      <button @click="handleAdd">Add</button>    </div>    <div>      <button        :class="{ active: filter === 'all' }"        @click="filter = 'all'"      >        All      </button>      <button        :class="{ active: filter === 'done' }"        @click="filter = 'done'"      >        Done      </button>      <button        :class="{ active: filter === 'undone' }"        @click="filter = 'undone'"      >        Undone      </button>    </div>    <ul>      <li v-for="todo in todos" :key="todo.id">        <input          type="checkbox"          :checked="todo.done"          @change="toggleTodo(todo.id)"        />        <span :class="{ done: todo.done }">{{ todo.text }}</span>        <button @click="deleteTodo(todo.id)">×</button>      </li>    </ul>  </div></template><style scoped>.todo-item {  display: flex;  align-items: center;  padding: 8px;  margin: 5px 0;  border: 1px solid #ddd;  border-radius: 4px;}.done {  text-decoration: line-through;  color: #888;}.input-group {  margin-bottom: 20px;  display: flex;  gap: 10px;}input {  flex: 1;  padding: 8px;}button {  padding: 8px 16px;  cursor: pointer;}.filters {  margin-bottom: 15px;  display: flex;  gap: 10px;}button.active {  background-color: #646cff;  color: white;}.delete-btn {  margin-left: auto;  padding: 0 8px;  background: none;  border: none;  font-size: 1.2em;  color: #ff4444;}</style>

6. 修改 main.ts

import { createApp } from 'vue'import { createPinia } from 'pinia'import App from './App.vue'const app = createApp(App)const pinia = createPinia()app.use(pinia)app.mount('#app')

7. 运行项目

npm run dev

主要功能说明:

  1. 使用 Pinia 进行状态管理

  2. 支持添加/删除待办事项

  3. 切换任务完成状态

  4. 过滤显示不同状态的任务

  5. 使用 TypeScript 进行类型检查

  6. 响应式状态管理

  7. 使用 Composition API

这个示例展示了 Vue 3 的组合式 API 与 Pinia 的结合使用,通过 TypeScript 的类型系统增强了代码的可维护性。Pinia 的状态管理逻辑集中在 store 中,组件主要负责 UI 交互和状态展示。


标签: 分享IT知识

相关文章

拖延症重度患者怎样自救

对于拖延症的重度患者,自救的关键在于以下几点:识别并克服拖延的借口。拖延常常因为我们害怕、不确定、不想不舒服而找到各种借口。我们必须识破这些借口,并对自己说:“如果我拖延,后果将不堪设想。”制定清晰的...

国庆节之后

国庆节之后,秋意渐浓,天空如洗,阳光更加灿烂。在这片美丽的土地上,繁华的都市和静谧的乡村都在庆祝这个重要的节日。国人们以独特的方式,让这个日子充满了色彩和热情。随着金秋的步伐,丰收的季节来临。果园中的...

西山经

《西山经》华山之首曰钱来之山。其上多松,其下多洗石。有兽焉,其状如羊而马尾,名曰羬羊,其脂可以已腊。西四十五里曰松果之山,濩水出焉,北流注于渭。其中多铜。有鸟焉,其名曰[虫鸟]渠,其状如山鸡,黑身赤足...

《山海经·大荒东经》节选翻译

在东海之外,有一个深不见底的大沟壑,那里是少昊的国度。少昊曾在此地养育了颛顼,并丢弃了他的琴瑟。有一座甘山,甘水从这座山中流出,最终汇聚成了甘渊。在大荒的东南角,有一座名为皮母地丘的高山。在东海之外,...

前端AI项目

一、‌开发效率提升‌‌智能代码生成‌‌场景‌:根据设计稿或自然语言描述生成前端代码。‌案例‌:‌Vercel v0‌:基于AI生成React代码,支持动态调整UI组件。‌Uizard‌:将手绘草图或F...

javascript 数据处理

JavaScript 提供了丰富的数据处理能力,涵盖数组、字符串、对象等核心数据结构的操作,以及高效的数据转换、存储和传输方法。以下是关键处理技巧和场景总结:‌一、数组处理‌‌遍历与转换‌map():...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。