百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

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

liuian 2025-06-09 23:32 3 浏览

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

相关推荐

WebRTC的拥塞控制技术(Congestion Control)

\1.概述对于共享网络资源的各类应用来说,拥塞控制技术的使用有利于提高带宽利用率,同时也使得终端用户在使用网络时能够获得更好的体验。在协议层面上拥塞控制是TCP的一个重要的组成部分;但是对于非面向...

当前端也拥有 Server 的能力(前端功能实现)

今天看了不少文章,比较感兴趣的是CacheAPI。它是浏览器Request/Response的缓存管理工具,其使用风格和运用场景让我瞬间联想到了ServiceWorker和FetchA...

Node 如何在 Controller 层进行数据校验

作者:山月行转发链接:https://mp.weixin.qq.com/s/UAU_Vpu3o53zqEAKDYgvQQ前言幽默风趣的后端程序员一般自嘲为CURDBoy。CURD,也就是对某一存...

JWT深度解析:现代Web身份验证的通行证-优雅草卓伊凡

JWT深度解析:现代Web身份验证的通行证为什么现在都是JWT为什么要restful-优雅草卓伊凡一、JWT的本质与构成1.1JWT的定义解析JWT(JSONWebToken)是一种开放标准(R...

Expo SDK 53.0.7 的 超详细 app.json 和 eas.json 配置项说明

以下是针对ExpoSDK53.0.7的超详细app.json和eas.json配置项说明,包含所有可能的配置项和实际用例:app.json完整配置手册(ExpoSDK53){...

搞懂JSON Schema:给数据加个“身份证”,不再“乱七八糟”!

JSON以其简洁、易读的特性广受欢迎,但当数据变得庞大、复杂,或者需要与多人协作时,你是不是也遇到过这些烦恼:“前端传来的数据格式不对,导致后端报错了!”“我的API文档写了一大堆,但别人还是不清楚数...

W3C 发布 WebAssembly 2.0 工作草案

4月20日,W3C公布了WebAssembly2.0的第一批公共工作草案。该草案由3部分组成,分别是:WebAssemblyCoreSpecification–Version...

ECMAScript标准制定过程展示及ES7新特性披露

2015年6正式发布的ES6是ECMAScript的最新版本,它的发布具有里程碑意义,不仅带来了众多的新特性,而且自此将改变ECMAScript的发布策略。本文将会介绍ECMAScript标准的最新...

微信小程序云开发教室预约系统的前后端交互与数据库设计

需求描述:需要申请使用教室时,可点击教室申请查看教室的使用状况及相关设备。确定好需要的教室后,按学期、校区、教学楼、周次、星期、节次、等维度筛选,并备注用途。例如:当我点击该教室申请占用后,该教室状态...

微软推出ManifoldJS,Web App自动转成各平台本地App

微软推出开源工具ManifoldJS,可以自动将WebApp转换成各种平台的App(安卓、iOS、ChromeOS、Windows)。ManifoldJS通过获取网站meta-data信息,即可产...

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

一星期前,我只是想看看大家是不是有同样的需求,于是我发了一篇《听说你需要一个云笔记,正好我们这里有一个》。结果到了第二天,这个当时只有README.md的项目,已经有好多的Star。后来,想了想这个A...

RK3588-HDMIRX(瑞芯微rk3588芯片手册)

1.简介专栏总目录HDMIIN功能可以通过桥接芯片的方式实现,将HDMI信号转换成MIPI信号接收,RK3588芯片平台自带HDMIRX模块,可以直接接收HDMI信号。本篇文章主要介绍在RK3...

分享一个功能强大的Android日志库XLog

XLog是什么腾讯开源的Mars项目中有个XLog日志库。XLog是一个高性能文本存储方案,在真实环境中经受了微信数亿级别的考验,具有很好的稳定性。由于其是使用C语言来实现的,故有占用性能、内存小,存...

Android系统基础(05) Android系统源码 调试

adbshell后面跟的命令主要来自:源码\system\core\toolbox目录和源码\frameworks\base\cmds目录。1adb命令@1常用命令adbget-prod...

Python与Appium实现自动化测试(python3 appium移动端自动化)

目录1.什么是Appium2.启动一个app自动化程序的步骤3.appium服务介绍4.appium客户端使用5.adb的使用6.Appium启动过程分析1.什么是Appiumappium是一个开源...