首页
/ VanJS项目实战:实现可编辑的待办事项列表

VanJS项目实战:实现可编辑的待办事项列表

2025-06-16 23:18:11作者:邬祺芯Juliet

前言

在Web开发中,待办事项(Todo List)是一个经典的学习案例,它涵盖了状态管理、UI渲染和用户交互等核心概念。本文将基于VanJS这个轻量级响应式UI库,深入讲解如何实现一个功能完善的待办事项应用,特别关注如何实现列表项的可编辑功能。

VanJS简介

VanJS是一个极简的JavaScript库,用于构建响应式用户界面。它采用声明式编程风格,通过简单的函数组合来创建UI组件,同时提供了响应式状态管理能力。VanJS的核心优势在于其极小的体积和直观的API设计。

待办事项应用设计

我们将实现一个具有以下功能的待办事项应用:

  1. 添加新的待办事项
  2. 标记事项为已完成
  3. 删除事项
  4. 编辑事项内容
  5. 本地存储持久化

核心实现解析

状态管理

首先,我们定义了两个状态类来管理应用数据:

class TodoItemState {
  constructor(text, done, deleted) {
    this.text = text; 
    this.done = done; 
    this.deleted = deleted;
  }
  serialize() { 
    return {text: this.text.val, done: this.done.val} 
  }
}

class TodoListState {
  constructor(todos) {this.todos = todos;}

  save() {
    localStorage.setItem("appState", JSON.stringify(
      (this.todos = this.todos.filter(t => !t.deleted.val)).map(t => t.serialize())))
  }

  static load = () => new TodoListState(
    JSON.parse(localStorage.getItem("appState") ?? "[]")
      .map((t) => new TodoItemState(van.state(t.text), van.state(t.done), van.state(false)))
  )

  add(text) {
    this.todos.push(new TodoItemState(van.state(text), van.state(false), van.state(false)))
    return new TodoListState(this.todos)
  }
}

这里的关键点在于:

  • 使用VanJS的state函数创建响应式状态
  • 实现了序列化和反序列化方法用于本地存储
  • 通过静态方法load从本地存储初始化状态

UI组件实现

待办事项项的组件实现如下:

const TodoItem = ({text, done, deleted}) => () => deleted.val ? null : div(
  input({type: "checkbox", checked: done, onclick: e => done.val = e.target.checked}),
  (done.val ? del(text) : input({type: "text", value: text.val, onchange: e => text.val = e.target.value})),
  a({onclick: () => deleted.val = true}, "❌"),
)

这个组件的亮点在于:

  1. 根据done状态动态切换显示方式
    • 已完成:显示删除线文本
    • 未完成:显示可编辑的输入框
  2. 实现了删除功能
  3. 完全响应式,状态变更自动更新UI

主应用组件

const TodoList = () => {
  const appState = van.state(TodoListState.load())
  van.derive(() => appState.val.save())
  const inputDom = input({type: "text"})
  return div(
    inputDom, 
    button({onclick: () => appState.val = appState.val.add(inputDom.value)}, "Add"),
    (dom) => dom ? 
      van.add(dom, TodoItem(appState.val.todos.at(-1))) : 
      div(appState.val.todos.map(TodoItem)),
  )
}

主组件负责:

  1. 初始化应用状态
  2. 设置状态变更时的自动保存
  3. 提供添加新事项的界面
  4. 渲染整个待办事项列表

关键技术点

响应式状态管理

VanJS使用state函数创建响应式状态变量。当状态值发生变化时,依赖该状态的UI会自动更新。在我们的实现中:

  • textdonedeleted都是响应式状态
  • 状态变更通过简单的赋值操作触发(state.val = newValue)

条件渲染

待办事项项的渲染根据状态动态变化:

  • deleted为true时,返回null表示不渲染
  • done为true时,使用del元素显示带删除线的文本
  • done为false时,显示可编辑的输入框

本地存储集成

通过localStorage实现了数据的持久化:

  1. save方法将状态序列化为JSON并存储
  2. load静态方法从存储中恢复状态
  3. 使用van.derive自动在状态变更时触发保存

总结

通过这个案例,我们展示了如何使用VanJS构建一个功能完整的待办事项应用。关键点包括:

  1. 合理的状态结构设计
  2. 响应式状态与UI的绑定
  3. 条件渲染实现不同状态的显示
  4. 本地存储集成实现数据持久化

这个实现虽然简洁,但涵盖了现代前端开发的核心理念。VanJS的轻量级特性使得开发者可以专注于业务逻辑,而不需要处理复杂的框架概念。对于初学者来说,这是一个很好的学习响应式编程和状态管理的案例。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
179
263
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
871
515
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
130
184
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
345
378
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
333
1.09 K
harmony-utilsharmony-utils
harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
ArkTS
30
0
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.08 K
0
kernelkernel
deepin linux kernel
C
22
5
WxJavaWxJava
微信开发 Java SDK,支持微信支付、开放平台、公众号、视频号、企业微信、小程序等的后端开发,记得关注公众号及时接受版本更新信息,以及加入微信群进行深入讨论
Java
829
22
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
601
58