网站首页 > 教程文章 正文
一星期前,我只是想看看大家是不是有同样的需求,于是我发了一篇《听说你需要一个云笔记,正好我们这里有一个》。结果到了第二天,这个当时只有README.md的项目,已经有好多的Star。
后来,想了想这个APP需要有一个中文名字吧,那就叫 墨乐,至少比摩尔好多了。
花了一周的时间来开发搭建基础的构建设施——我们需要支持Web、移动设备、桌面版,未来会考虑直接开发Chrome插件。
基础设施
早期为了图个方便,使用了react-starter-kit模板,掉到了坑里。后来又换成了react-static-boilerplate模板,又掉到了坑里。毕竟都满足不了我的需求,只要想办法重写一些基础设施(脚本)。
同样的,和之前的Growth一样,我们也是《一份代码构建移动、桌面、Web全平台应用》
Web——GitHub Page发布。react-static-boilerpalte提供了一个脚本可以直接发布代码到GitHub Page,只是这个脚本是有问题的,作者也还没修好。目前对于我来说,这个优先级不高。
Mobile——支援Android和iOS等移动版本。由于使用的是React MDL作为UI框架,所以只需要写点简单的Cordova脚本就可以实现打包,如:
#!/usr/bin/env bash
npm run build
cd mobile
cordova run android
Desktop——支援Electron桌面。同样的,先简单的写个脚本来实现:
./node_modules/electron-prebuilt/cli.js desktop/main.js
基础技术栈
由于我的React的技术栈还停留在一年前,所以我还不得不尽量去了解一些新的趋势。总的来说改变还不是很大——除了React的版本,从0.14直接到15.3.0。但是,我发现我写React代码的感觉好像不是很好。之前写的项目,没怎么写测试,囧囧囧囧囧囧囧。。。
UI框架选用的是React MDL——只是我想说,这可能上不了APP Store。
Ajax用的是Fetch,包名whatwg-fetch
当然,少不了Webpack
Redux,还没用上
其他的一些基础框架还包括:
moment,用于显示时间
jsdiff,用于diff修改
github-api,一个简单好用的GitHub API封装
draft.js,用于未来提供富文本支持
to-markdown和markdown-it,用于用富文本提供转换支持,似乎不是很完善
babel,ES6语法支持
Demo和截图
除了最初设定好的云笔记的功能,未来我还会将我需要的 TODO 和 Idea加进去~~。
TODO LISTS,一般人都知道。
Idea,就是根据我的Ideas项目创建的,这里的创建就会在GitHub上直接创建一个Issue。
同步的基本原理
对于同步功能来说,当前设计的功能比较简单。
当我打开首页的时候,我会从GitHub上获取一个all.json文件。这个文件存储有笔记的一些基本信息,如标题、相对路径、创建时间、修改时间。其中的修改时间便是用于同步。
当我修改完某个笔记的时候,我将调用GitHub API,直接写入新的笔记,并更新all.json这个API文件。
而调用API的关键就是使用GitHub Token——因为我的GitHub启用了两步验证,所以我用不了一般的登录方式。
访问
https://phodal.github.io/mole-web/ 即可在线预览。
不过,有相当多的功能都没有,而且还有一堆Bug等着修。
说了这么多,你想加入我们的开发吗?
先设定一个比较小的目标,比如在给我们一个Pull Request。
如果你实现不了这个小目标,那么就留言吧。
https://github.com/phodal/mole
猜你喜欢
- 2025-06-03 Astro 2.1 正式发布(astro25)
- 2025-06-03 大模型技术:详解LangGraph,从基础到高级
- 2025-06-03 「官方」Redux 编码规范(redux-toolkit)
- 2025-06-03 phpBB管理控制面板代码中惊现CSRF漏洞
- 2025-06-03 WebRTC的拥塞控制技术(Congestion Control)
- 2025-06-03 当前端也拥有 Server 的能力(当前web前端最新技术有哪些?)
- 2025-06-03 关于写一个NodeJS库补上org生态缺失的一环这件事
- 2025-06-03 Node 如何在 Controller 层进行数据校验
- 2025-06-03 前端如何做大量的数据校验?json schema配置详解
- 2025-06-03 搞懂JSON Schema:给数据加个“身份证”,不再“乱七八糟”!
- 最近发表
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- mybatis plus page (35)
- vue @scroll (38)
- 堆栈区别 (33)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)
- redis aof rdb 区别 (33)
- 302跳转 (33)
- http method (35)
- js array splice (33)