为了账号安全,请及时绑定邮箱和手机立即绑定

Vue.js打造一个开源的CNode社区

标签:
Vue.js

Vue.js打造一个开源的CNode社区

Vue.js打造一个开源的CNode社区,实现了浏览、发帖、收藏、回复、点赞、个人中心等等功能。

源代码

源代码地址: https://github.com/microzz/vue-cnode

欢迎大家star和fork

预览

在线预览地址: https://microzz.com/vue-cnode/

技术栈

  • Vue2.0:前端页面展示。

  • Vuex:Vuex,实现不同组件间的状态共享

  • vue-router:页面路由切换

  • axios:一个基于 Promise 的 HTTP 库,向后端发起请求。

  • ExpressKoa2:因为vue-cli生成的项目是基于express的,所以在开发阶段我使用的是它,但是真正上线生产环境我换成了Koa2

  • Moment.js:一个时间处理的库,方便对时间进行格式化成需要的格式,如主题、回复时间显示"* 分钟前、* 小时前、*天前"等等。

  • ES6ES7:采用ES6语法,这是以后的趋势。箭头函数、Promise等等语法很好用。

  • localStorage:保存用户信息。

  • Canvas:页面顶部小雪花效果。

  • Webpack:vue-cli自带Webpack,但是需要自己改造一下,比如要对需要安装sass相关loader,vue-cli已经配置好了webpack,你只需要安装依赖就可以,使用的时候只需要<style></style>

  • SASS(SCSS):用SCSS做CSS预处理语言,有些地方很方便,个人很喜欢用。(详看SASS用法指南)

  • flex:flex弹性布局,简单适配手机、PC端。

  • CSS3:CSS3过渡动画及样式。

总结

  1. 组件状态多了用Vuex管理很方便,引用 Redux 的作者 Dan Abramov 的话说就是:

Flux 架构就像眼镜:您自会知道什么时候需要它。

  1. 事先一定要先想好整个页面组成,怎样去分组件开发,这样在开发阶段会事半功倍。

  2. Moment.js在Vue中用ES6的方式引入会有问题,可以尝试在main.js尝试这样import moment from 'moment' Vue.prototype.moment = moment;给Vue的原型上添加moment,这样就可以在Vue的实例中随意使用它了。

  3. 项目结构如下图

Vue-CNode by microzz.comVue-CNode by microzz.com

时间轨迹

  • 4.13:基本功能完成,后续完成登录后的操作。

  • 4.14:完成登录以及侧边栏。

  • 4.15:增加收藏

  • 4.16:加入回复、单条回复、点赞。项目完成。

About

源代码地址: GitHub

个人网站: microzz.com

GitHub: microzz

Build Setup

# install dependencies npm install # serve with hot reload at localhost:8080 npm run dev # build for production with minification npm run build # build for production and view the bundle analyzer report npm run build --report



作者:microzz
链接:https://www.jianshu.com/p/07721a541e0e


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消