早期为了图个方便,使用了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语法支持
除了最初设定好的云笔记的功能,未来我还会将我需要的 TODO 和 Idea加进去~~。
TODO LISTS,一般人都知道。
Idea,就是根据我的Ideas项目创建的,这里的创建就会在GitHub上直接创建一个Issue。
对于同步功能来说,当前设计的功能比较简单。
当我打开首页的时候,我会从GitHub上获取一个all.json文件。这个文件存储有笔记的一些基本信息,如标题、相对路径、创建时间、修改时间。其中的修改时间便是用于同步。
当我修改完某个笔记的时候,我将调用GitHub API,直接写入新的笔记,并更新all.json这个API文件。
而调用API的关键就是使用GitHub Token——因为我的GitHub启用了两步验证,所以我用不了一般的登录方式。
网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。
加入交流群
请使用微信扫一扫!