(5)从零开发 Chrome 插件:Vue3 Chrome 插件待办事项应用

(1)从零开发 Chrome 插件:构建你的第一个插件
(3)从零开发 Chrome 插件:实现 API 登录与本地存储功能
(3)从零开发 Chrome 插件:网页图片的批量下载
(4)从零开发 Chrome 插件:Chrome插件调试全攻略
(5)从零开发 Chrome 插件:Vue3 Chrome 插件待办事项应用

Vue3 Chrome 插件待办事项应用

功能概述

一个基于Vue3的Chrome插件待办事项应用,具有以下功能:

  • 添加/删除待办事项
  • 标记完成状态
  • 数据自动保存到Chrome存储
  • 响应式界面设计

功能实现

添加待办事项

标记事项为已完成 / 未完成

删除单个事项

清空所有事项

技术栈

  • Vue 3 - 前端框架
  • Chrome Extension API - 浏览器扩展功能
  • Tailwind CSS - 样式设计
  • Vite - 构建工具

技术要点

数据持久化:

  • 使用 chrome.storage.sync 存储数据

响应式设计:

  • 使用 Tailwind CSS 实现响应式布局
  • 适配不同屏幕尺寸

核心代码实现

项目结构

javascript 复制代码
vue3-todo-chrome-extension/
├── src/
│   ├── App.vue          # 主组件
│   ├── main.js          # 入口文件
├── public/
│   ├── manifest.json    # 插件清单
├── package.json         # 项目配置

数据存储

javascript 复制代码
// 初始化数据
onMounted(() => {
  chrome.storage.sync.get(['todos', 'lastUpdated'], (result) => {
    if (result.todos) todos.value = result.todos
    if (result.lastUpdated) lastUpdated.value = result.lastUpdated
  })
})

// 监听数据变化
watch(todos, (newTodos) => {
  chrome.storage.sync.set({
    todos: newTodos,
    lastUpdated: Date.now()
  })
}, { deep: true })

待办事项管理

javascript 复制代码
// 添加待办
const addTodo = () => {
  if (newTodo.value.trim() === '') return
  
  todos.value.push({
    id: Date.now(),
    text: newTodo.value,
    completed: false
  })
  
  newTodo.value = ''
}

界面组件

javascript 复制代码
<div class="space-y-2 mb-6 max-h-60 overflow-y-auto pr-1">
  <div 
    v-for="(todo, index) in todos" 
    :key="todo.id"
    class="flex items-center p-3 border rounded-lg hover:bg-gray-50 transition duration-200"
  >
    <input 
      type="checkbox" 
      :checked="todo.completed"
      @change="toggleTodo(index)"
    >
    <span :class="todo.completed ? 'line-through text-gray-400' : 'text-gray-800'">
      {{ todo.text }}
    </span>
    <button @click="deleteTodo(index)">
      <i class="fa fa-trash-o"></i>
    </button>
  </div>
</div>

安装与使用

    1. 安装依赖
bash 复制代码
npm install
  • 2.开发模式:
bash 复制代码
npm run dev
    1. 构建生产版本:
bash 复制代码
npm run build
    1. 在Chrome中加载dist目录作为扩展程序

特点

响应式设计,适配不同屏幕尺寸

数据自动保存,关闭浏览器后仍可恢复

简洁直观的用户界面

轻量级,快速加载

总结

这个Chrome插件展示了如何结合Vue 3的响应式特性和Chrome扩展API,实现一个功能完整、数据持久的待办事项应用。通过组合式API,代码结构清晰易维护,而Tailwind CSS则提供了美观的界面样式。

相关推荐
江城开朗的豌豆18 小时前
拆解微信小程序的“积木盒子”:这些原生组件你都玩明白了吗?
前端·javascript·微信小程序
前端达人18 小时前
「React实战面试题」:React.memo为什么失效了?
前端·javascript·react.js·前端框架·ecmascript
江城开朗的豌豆18 小时前
嘿,别想那么复杂!我的第一个微信小程序长这样
前端·javascript·微信小程序
Irene199118 小时前
URLSearchParams :处理 URL 查询参数的接口
开发语言·前端·javascript
LFly_ice18 小时前
学习React-19-useDebugValue
javascript·学习·react.js
Dontla18 小时前
Web典型路由结构之Next.js (App Router, v13+) )(文件系统驱动的路由:File-based Routing)声明式路由:文件即路由
开发语言·前端·javascript
岁月宁静18 小时前
Vue3.5 + SSE 构建高可用 AI 聊天交互层 ——chat.js 模块架构与实现
前端·vue.js·人工智能
~无忧花开~18 小时前
JavaScript学习笔记(十七):ES6生成器函数详解
开发语言·前端·javascript·笔记·学习·es6·js
前端 贾公子18 小时前
Vue3 defineModel === 实现原理
前端·javascript·vue.js
snowbitx18 小时前
一篇文章彻底搞懂前端架构层面分层设计
前端·设计模式·前端框架