开源软件名称:luoye-fe/goh5
开源软件地址:https://github.com/luoye-fe/goh5
开源编程语言:
JavaScript
81.6%
开源软件介绍:GoH5
预览地址
GoH5
GoH5是一个可视化编辑手机H5页的工具,极大解放生产力也为创意无限的人们提供展示的机会。
市面上类似的工具很多,易企秀、初页、兔展等等,功能很强大,但是作为个人开源项目,GoH5的出现不仅是为了做这个可视化工具,更是对自己的一个锻炼,从后端到前端甚至UI,每一行代码累过来,也许粗糙,也许离生产还有段距离,但最大的收获是思路的拓展。
长什么样?
用了哪些技术?
-
数据库:MongoDB
-
后台:NodeJs、Express
-
前台:
-
编辑页:Vue、Vuex、Vue-Router、jQuery
-
展示页:Swiper
-
构建:Gulp、Webpack
怎么启动项目?
-
克隆本项目源代码
git clone https://github.com/luoye-fe/goh5.git
-
安装本项目依赖包
-
启动本地MongoDB服务
本项目数据库用的是MongoDB,所以需要先在本地启动MongoDB服务,并且新建一个名为 goh5 的数据库,详情见 MongoDB的安装和使用
// 本机
mongod --dbpath ~/data/db
-
拷贝数据库配置
cp ./RESTful_API/db/config.js.sample ./RESTful_API/db/config.js
-
启动服务
node app.js --env=dev // 开发模式
or
pm2 start server.json // 生产
-
前端代码实时编译
进入到 Back_Stage 执行 gulp watch 实时编译编辑后台的代码。
进入到 Front_Stage 执行 gulp watch 实时编译预览页的代码。
-
查看效果
浏览器打开 localhost:3030 就可以看到效果啦
技术细节?
-
Vue
感谢尤大带来生产力的解放。。
本项目前端部分的主要实现就是依靠Vue,整个应用的状态都依赖一个H5作品的原始的数据,作为数据驱动的框架,Vue可以完美的应用在本项目中。
在项目初期,一直用数据的双向绑定实现应用状态的更新,但是组件多了,数据交换多了之后数据管理起来极其复杂,此时引入了Vuex,类似Redux的数据流管理插件,所有的数据修改操作集中到store中,保证了整个应用的稳定性。
路由部分,使用的Vue的Vue-Router,整个项目大多是单页,路由部分并不复杂。
-
MongoDB
为什么用MongoDB呢?因为这样的话前后端的数据模型保持一致,请求接口,数据不用特殊处理,前端就可以直接用,json型的数据极其方便。
-
NodeJs
没什么好说的,就是好。
-
-
构建
构建用的是 gulp+webpack ,开发模式时运行 gulp watch 实时监控代码,实时打包和更新。
发布新版本时,修改前台或后台文件夹下的 config.json 中的 version ,然后运行 gulp --env=pro 进行压缩打包并更新静态文件时间戳。
未来?
联系我?
有任何问题或者想交流的开issue或者联系邮箱[email protected]。
|
请发表评论