云计算、AI、云原生、大数据等一站式技术学习平台

网站首页 > 教程文章 正文

听说你需要一个云笔记,正好我们做了一个

jxf315 2025-06-03 22:49:00 教程文章 12 ℃

一星期前,我只是想看看大家是不是有同样的需求,于是我发了一篇《听说你需要一个云笔记,正好我们这里有一个》。结果到了第二天,这个当时只有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

Tags:

最近发表
标签列表