商店地址:tiny todo list
Github:tiny-todo-list
业余写了款基于 Chrome 的轻量任务清单扩展 - ttl (tiny todo list),写来原因有一二:
因为相信看这篇的大多数都是开发,所以除了介绍对清单 todolist 的理解,另外就是适当穿插一些开发使用到的框架和 API 接口介绍。
这是个有趣的事情,因为前端虽然一直在小步快跑,但近几年国内主流的开发应该是在 Vue,React 中切换,变的是一次次版本升级带来的用法差异,不变的是这几款框架基本已经确定了自己的江湖地位,就像在前端编译构建阶段,Webpack 已经是无人撼动的地位,偏偏有个愣头青搞起了 rollup。嗤之以鼻的人说这是蜉蝣撼大树,不安分的人会心生几分敬意,少年有种勇者斗恶龙的气概,而正是这个愣头青又盘算起了前端框架,就是这个 Svelte,已经到了 v3 版本,简单介绍下:
虽说生态如此,但后发总比先来的有优势是铁板的事情,毕竟从模板语法上能看到学习了不少 Vue 的长处,同时干掉了虚拟 DOM,没有中间商赚差价,开发直接燥起来。
相关文档:Svelte 官方文档
Chrome 扩展单纯说前端开发又不能完全涵盖,可以说是一个前端练手微项目的绝佳机会。为什么算是微项目:
popup
和background
之前类似前后台的交互 - 可以看做是前后端请求如果想了解下这个小身材却有大内容的开发,英文又不一定那么好,那么墙裂推介这个非官方的开发者文档,而如果你恰巧对说明性文档不感兴趣,可以看看我写过的一篇问答式入门文档写个 Markdown 插件,讲讲 Chrome 扩展开发
有了前边提到的原因一二,和上手练练新框架的想法,就开始上手做了。但还是要说一个做之前就考虑的问题。
先前开发SPS时,使用了 Chrome 为每一款扩展提供了 100kb 的同步功能。这是个神奇的 100kb, 有了这 100kb 存储,可以做到无需单独账号登陆系统,就可以同步更新。但当你想在 100kb 范围内存储一批数据时,又会遇到一个问题:每一个对象存储不能超过 8kb,也就是说给了你自由,又给了你套了层枷锁,终究没办法翩翩起舞。这也是 SPS 限制存储 40 首(甚至有些情况不到 40 首 bug )的原因。
怎么办,如何在不注册登录(表层原因是不想存储任何用户数据,不作恶,深层原因是还需要自己做数据存储,麻烦),又能让用户肆意存储。有了问题,就考虑这么一个免费的存储空间,嗯,Github issue 看好你哟。所以简单测试下,bingo,就用它了。
相关 API 文档:
说到功能需求,不得不说说我所用到的一些 todolist.作为开发和工具爱好者,对工具有些执念: 希望它能简单。这一点偏偏 todoist 做的是重了又重,太多没用的总搞得不是很得劲,有时候还会遇到登陆不上的问题,麻烦。
在找到一款Simple To-Do List简单有好用的扩展后,深度使用还是发现了几处致命问题:
查看了下作者更新时间是多年前了,所以理想的简约不简单还是有那么一些距离,就梳理下自己的需求:
进行中的任务需要能够支持不同状态
常规 todolist 只能展示完成 /未完成两个状态,有时候在任务完成前,没有看到任务进展会有一种挫败感心理
TTL 做了什么:
complete
条目中forgotten
条目中需要支持清单任务描述
Simple To-Do List
简单极致到只能创建任务,却不能对任务做一些基本描述
TTL 做了什么
需要支持强迫症模式
创建一定数量任务如未完成,则限制创建新任务
TTL 做了什么
需要支持遗忘模式
因为经常会遇到创建任务后,但又根本不重要,结果一直躺在任务列表,怎么办。
TTL 做了什么 长时间未更新的任务直接进入回收站(Forgotten)
chrome.storage
同步,这样遇到多台 PC 的情况,没办法做到信息同步这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.