vue3组件化开发优势劣势分析,及一个案例

Vue 3 组件化开发的优势和劣势

优势

可复用性:

组件可以重复使用,减少代码冗余,提高开发效率。

可以在不同的项目中复用组件,提升开发速度。

可维护性:

组件化开发使得代码结构清晰,易于维护。

每个组件独立,修改一个组件不会影响其他组件。

模块化:

组件化开发符合模块化编程思想,便于团队协作。

每个组件可以独立开发和测试,提高开发效率。

灵活性:

Vue 3 提供了 Composition API 和 script setup 语法,使得逻辑组织和复用更加灵活。

可以根据需求选择 Options API 或 Composition API。

性能优化:

Vue 3 的响应式系统和虚拟 DOM 优化了性能,组件化开发可以更好地利用这些优化。

劣势

学习曲线:

对于新手来说,理解组件化开发和 Vue 3 的新特性(如 Composition API 和 script setup)可能需要一些时间。

复杂性:

在大型项目中,组件数量可能会非常多,管理这些组件和它们之间的通信可能会变得复杂。

过度抽象:

如果过度使用组件化,可能会导致代码过于抽象,增加理解和维护的难度。

案例:使用 script setup 实现一个简单的 TodoList

项目结构

复制代码
src/
│
├── components/
│   ├── TodoList.vue
│   ├── TodoItem.vue
│   └── AddTodo.vue
│
├── App.vue
└── main.js
1. TodoItem.vue - 单个任务项组件
复制代码
<template>
  <li>
    <span :class="{ completed: todo.completed }">{{ todo.text }}</span>
    <button @click="toggleComplete">Toggle</button>
    <button @click="deleteTodo">Delete</button>
  </li>
</template>

<script setup>
const props = defineProps({
  todo: {
    type: Object,
    required: true,
  },
});

const emit = defineEmits(['toggle-complete', 'delete-todo']);

const toggleComplete = () => {
  emit('toggle-complete', props.todo.id);
};

const deleteTodo = () => {
  emit('delete-todo', props.todo.id);
};
</script>

<style scoped>
li {
  list-style: none;
  margin: 10px 0;
}

button {
  margin-left: 10px;
}

.completed {
  text-decoration: line-through;
  color: gray;
}
</style>
2. TodoList.vue - 任务列表组件
复制代码
<template>
  <ul>
    <TodoItem
      v-for="todo in todos"
      :key="todo.id"
      :todo="todo"
      @toggle-complete="handleToggleComplete"
      @delete-todo="handleDeleteTodo"
    />
  </ul>
</template>

<script setup>
import TodoItem from './TodoItem.vue';

const props = defineProps({
  todos: {
    type: Array,
    required: true,
  },
});

const emit = defineEmits(['toggle-complete', 'delete-todo']);

const handleToggleComplete = (todoId) => {
  emit('toggle-complete', todoId);
};

const handleDeleteTodo = (todoId) => {
  emit('delete-todo', todoId);
};
</script>

<style scoped>
ul {
  padding: 0;
}
</style>
3. AddTodo.vue - 添加任务组件
复制代码
<template>
  <div>
    <input v-model="newTodo" @keyup.enter="addTodo" placeholder="Add a new task" />
    <button @click="addTodo">Add</button>
  </div>
</template>

<script setup>
import { ref } from 'vue';

const newTodo = ref('');

const emit = defineEmits(['add-todo']);

const addTodo = () => {
  if (newTodo.value.trim()) {
    emit('add-todo', newTodo.value);
    newTodo.value = '';
  }
};
</script>

<style scoped>
input {
  margin-right: 10px;
}
</style>
4. App.vue - 主组件
复制代码
<template>
  <div id="app">
    <h1>Todo List</h1>
    <AddTodo @add-todo="handleAddTodo" />
    <TodoList :todos="todos" @toggle-complete="handleToggleComplete" @delete-todo="handleDeleteTodo" />
  </div>
</template>

<script setup>
import { ref } from 'vue';
import AddTodo from './components/AddTodo.vue';
import TodoList from './components/TodoList.vue';

const todos = ref([
  { id: 1, text: 'Learn Vue 3', completed: false },
  { id: 2, text: 'Build a project', completed: false },
]);

const handleAddTodo = (newTodoText) => {
  todos.value.push({
    id: todos.value.length + 1,
    text: newTodoText,
    completed: false,
  });
};

const handleToggleComplete = (todoId) => {
  const todo = todos.value.find((t) => t.id === todoId);
  if (todo) {
    todo.completed = !todo.completed;
  }
};

const handleDeleteTodo = (todoId) => {
  todos.value = todos.value.filter((t) => t.id !== todoId);
};
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>
5. main.js - 入口文件
复制代码
import { createApp } from 'vue';
import App from './App.vue';

createApp(App).mount('#app');
运行项目

在项目根目录下运行以下命令来启动开发服务器:

复制代码
npm run serve

总结

使用 script setup 语法更简洁地编写 Vue 3 组件,减少样板代码。

组件化开发使得代码结构清晰,易于维护和扩展。

这个案例展示了如何使用 Vue 3 的响应式系统和组件化开发模式构建一个功能完整的 TodoList 应用。

相关推荐
麦麦大数据44 分钟前
J002 Vue+SpringBoot电影推荐可视化系统|双协同过滤推荐算法评论情感分析spark数据分析|配套文档1.34万字
vue.js·spring boot·数据分析·spark·可视化·推荐算法
BUG创建者4 小时前
html获取16个随机颜色并不重复
css·html·css3
BillKu5 小时前
Vue3 + Element-Plus 抽屉关闭按钮居中
前端·javascript·vue.js
DevilSeagull5 小时前
JavaScript WebAPI 指南
java·开发语言·javascript·html·ecmascript·html5
面向星辰6 小时前
html中css的四种定位方式
前端·css·html
Async Cipher6 小时前
CSS 权重(优先级规则)
前端·css
大怪v6 小时前
前端佬:机器学习?我也会啊!😎😎😎手“摸”手教你做个”自动驾驶“~
前端·javascript·机器学习
gnip9 小时前
链式调用和延迟执行
前端·javascript
杨天天.9 小时前
小程序原生实现音频播放器,下一首上一首切换,拖动进度条等功能
前端·javascript·小程序·音视频
Dragon Wu9 小时前
React state在setInterval里未获取最新值的问题
前端·javascript·react.js·前端框架