一个纯前端的网站集合管理工具

本地化网站管理平台

一个纯前端的网站集合管理工具,支持本地数据存储、完整的CRUD操作,可作为 Chrome 扩展使用。

功能特性

核心功能

  • 网站管理:完整的增删改查功能
  • 图片上传:支持上传网站图标(存储到IndexedDB)
  • APIKeys管理:支持多个APIKeys,脱敏显示,一键复制
  • 分类系统:支持自定义分类(带图标选择)
  • 标签系统:支持自定义标签,多维度筛选
  • 搜索功能:支持按网站名称、描述、URL搜索
  • 本地存储:所有数据存储在浏览器IndexedDB中,无需服务器
  • 导入导出:支持 JSON 格式的数据导入导出

技术栈

  • 框架 :Vue 3 (Composition API + <script setup>)
  • 语言:TypeScript(宽松模式)
  • 构建工具:Vite
  • 样式:Tailwind CSS
  • 数据库:Dexie.js (IndexedDB封装)
  • 图标:Material Design Icons
  • 状态管理:Pinia

快速开始

安装依赖

bash 复制代码
npm install

开发模式

bash 复制代码
npm run dev

访问 http://localhost:3000

构建 Chrome 扩展

bash 复制代码
# Windows
pack.bat

# Linux/Mac
./pack.sh

构建完成后,dist 目录包含完整的 Chrome 扩展文件。

安装 Chrome 扩展

  1. 打开 Chrome,访问 chrome://extensions/
  2. 开启右上角的 开发者模式
  3. 点击 加载已解压的扩展程序
  4. 选择项目的 dist 文件夹

点击扩展图标即可打开工具集。

项目结构

csharp 复制代码
links/
├── src/
│   ├── components/          # 组件
│   │   ├── layouts/        # 布局组件
│   │   │   ├── Header.vue
│   │   │   ├── Sidebar.vue
│   │   │   └── MainContent.vue
│   │   ├── website/       # 网站相关组件
│   │   │   ├── WebsiteCard.vue
│   │   │   ├── WebsiteDetailDrawer.vue
│   │   │   ├── WebsiteForm.vue
│   │   │   ├── ImageUploader.vue
│   │   │   └── ApiKeyInput.vue
│   │   ├── filter/        # 筛选组件
│   │   │   ├── SearchBar.vue
│   │   │   ├── CategoryFilter.vue
│   │   │   └── TagFilter.vue
│   │   └── common/        # 通用组件
│   │       ├── ThemeSwitcher.vue
│   │       ├── CategoryDialog.vue
│   │       └── TagDialog.vue
│   ├── composables/        # 组合式函数
│   │   ├── useDexie.ts
│   │   ├── useWebsites.ts
│   │   ├── useCategories.ts
│   │   ├── useTags.ts
│   │   ├── useImageUpload.ts
│   │   ├── useApiKey.ts
│   │   └── useTheme.ts
│   ├── db/                 # 数据库
│   │   ├── index.ts        # Dexie实例
│   │   └── seed.ts         # 预置数据
│   ├── stores/             # Pinia状态管理
│   │   └── app.ts
│   ├── types/              # TypeScript类型定义
│   │   └── index.ts
│   ├── utils/              # 工具函数
│   │   ├── validators.ts
│   │   ├── formatters.ts
│   │   └── constants.ts
│   └── styles/             # 样式文件
│       ├── main.css
│       └── themes/
│           └── neumorphism.css
├── public/
│   ├── background.js       # Chrome 扩展 background script
│   └── tools.png           # 扩展图标
├── manifest.json           # Chrome 扩展配置
├── vite.config.js          # Vite 配置
├── pack.bat                # Windows 打包脚本
└── pack.sh                 # Linux/Mac 打包脚本

使用说明

添加网站

  1. 点击右上角"添加"下拉菜单,选择"添加网站"
  2. 填写网站信息:
    • 名称(必填)
    • URL(必填)
    • 图标(推荐128-256px,<500KB)
    • 描述
    • 分类(必填)
    • 标签(多选)
    • APIKeys(可选,可添加多个)
  3. 点击"添加"保存

管理网站

  • 点击网站卡片查看详情
  • 详情中可以查看APIKeys(脱敏显示)
  • 支持复制完整APIKey
  • 支持编辑和删除网站

筛选网站

  • 使用左侧分类导航筛选
  • 使用标签复选框多选筛选
  • 使用顶部搜索栏搜索

导入导出数据

点击右上角"添加"下拉菜单:

  • 导出数据:下载当前所有数据的 JSON 文件
  • 导入数据:选择 JSON 文件导入,支持合并或替换模式

数据存储

所有数据存储在浏览器的IndexedDB中:

  • SitesDB 数据库名
  • 包含3个表:websites, categories, tags
  • 数据只在本地,不会上传到任何服务器

注意事项

  1. 图片大小:建议上传的图标小于500KB,推荐128-256px
  2. APIKey安全:APIKeys存储在本地IndexedDB中,请妥善保管浏览器数据
  3. 数据备份:定期导出数据作为备份
  4. 浏览器兼容性:支持现代浏览器(Chrome, Firefox, Safari, Edge)

许可证

MIT License

相关推荐
发现一只大呆瓜2 小时前
深度解密 Rollup 插件开发:核心钩子函数全生命周期图鉴
前端·vite
java_nn2 小时前
一文了解前端技术
前端
发现一只大呆瓜2 小时前
深度解析 Rollup 配置与 Vite 生产构建流程
前端·vite
小码哥_常3 小时前
安卓黑科技:让手机成为你的“跌倒保镖”
前端
小李子呢02114 小时前
前端八股Vue---Vue2和Vue3的区别,set up的用法
前端·javascript·vue.js
m0_647057964 小时前
Harness Engineering 实践指南
前端
邂逅星河浪漫4 小时前
【银行内网开发-管理端】Vue管理端+Auth后台开发+Nginx配置+Linux部署(详细解析)
linux·javascript·css·vue.js·nginx·html·前后端联调
JJay.4 小时前
Android BLE 稳定连接的关键,不是扫描,而是 GATT 操作队列
android·服务器·前端
一 乐4 小时前
电影院|基于springboot + vue电影院购票管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·电影院购票管理管理系统
星空椰4 小时前
JavaScript 进阶基础:函数、作用域与常用技巧总结
开发语言·前端·javascript