Vue仿今日头条实例详解


Posted in Javascript onFebruary 06, 2018

前言

vue也弄了一段时间了, 前段时间一直想用vue写个移动端,加之年底也不是很忙,于是前几天便着手开始弄了,到今天为止也算是勉强能看了

因为也是纯粹的写写前端页面,所以数据方面用的是mock.js,为了真实的模拟请求,可以直接在 Easy Mock 自己生成API
也可直接登陆我这项目的Easy Mock账号密码:

账号: vue-toutiao
密码: 123456

如果你想修改接口,请copy一份在修改

如果你想后台接口也自己开发的话。可以阅读我这篇博客 Vue + Node + Mongodb 开发一个完整博客流程

技术栈:

vue + webpack + vuex + axios

结构:

  • build: webpack配置
  • config: 项目配置参数
  • src
  • assets: 静态资源文件,存放图片啥的
  • components: 常用组件。例如 弹窗 等等。。。
  • directive: 常用指令封装
  • router: 路由表
  • store: 状态管理 vuex
  • styles: 样式文件
  • utils: 常用工具类封装
  • views: 视图页面
  • static: 静态文件: 存放 favicon.ico 等等
  • 此项目用到了 DllPlugin 进行打包处理,所有启动该项目时记得,先执行一次该脚本命令生成配置

效果演示:

Vue仿今日头条实例详解

Vue仿今日头条实例详解

Vue仿今日头条实例详解

Vue仿今日头条实例详解

Vue仿今日头条实例详解

几个常用的知识点

1. 路由懒加载

{
  path: '/development',
  name: 'development',
  component: (resolve) => {
    require(['../views/development.vue'], resolve)
  }
}

const _import_ = file => () => import('views/' + file + '.vue')

{
  path: '/development',
  name: 'development',
  component: _import_('development')
}

2. 登陆拦截

通过路由的 beforeEach 钩子函数来判断是否需要登陆

// 如:系统设置需要登陆
{ 
  path: '/system', 
  name: '系统设置', 
  meta: { 
    login: true
  },
  component: _import_('System/index')
}

router.beforeEach((to, from, next) => {
  if (to.meta.login) { //判断前往的界面是否需要登陆
    if (store.state.user.user.name) { // 是否已经登陆
      next()
    }else{
      Vue.prototype.$alert('请先登录!')
        .then( () => {
          store.state.user.isLogin = true
        })
    }
  }else{
    if (to.meta.page) store.state.app.pageLoading = true
    next() 
  }
  
})

3. 动画切换

通过检测设置在 Router上的animate属性 来判断它做什么样的切换动画

Router.prototype.animate = 0

// 获取每个路由meta上面的slide 来判断它做什么动画
{ 
  path: '/system', 
  name: '系统设置', 
  meta: { 
    slide: 1 
  },
  component: _import_('System/index')
}


watch: {
  $route (to, from) {
    /*
    0: 不做动画
    1: 左切换
    2: 右切换
    3: 上切换
    4: 下切换
    ...
     */
    let animate = this.$router.animate || to.meta.slide
    if (!animate) {
      this.animate = '' 
    }else{
      this.animate = animate === 1 ? 'slide-left' :
        animate === 2 ? 'slide-right' :
        animate === 3 ? 'slide-top' :
        animate === 4 ? 'slide-bottom' : ''
    }
    this.$router.animate = 0
  }
}

4. 视频播放

因为在IOS上 无法隐藏video的controls ,所以我们可以隐藏video,通过绘制canvas来达到播放视频的效果

5. icon采用的是 阿里巴巴矢量图

6. mock.js

7. Easy Mock

代码实例:https://github.com/cd-dongzi/vue-project/tree/master/vue-toutiao

Javascript 相关文章推荐
javascript 广告后加载,加载完页面再加载广告
Nov 25 Javascript
jquery复选框全选/取消示例
Dec 30 Javascript
jQuery实现动态表单验证时文本框抖动效果完整实例
Aug 21 Javascript
基于javascript实现全国省市二级联动下拉选择菜单
Jan 28 Javascript
如何使用Vuex+Vue.js构建单页应用
Oct 27 Javascript
ES6教程之for循环和Map,Set用法分析
Apr 10 Javascript
初识 Vue.js 中的 *.Vue文件
Nov 22 Javascript
Vue实现双向绑定的原理以及响应式数据的方法
Jul 02 Javascript
实例讲解v-if和v-show的区别
Jan 31 Javascript
如何使用CSS3+JQuery实现悬浮墙式菜单
Jun 18 jQuery
Vue全局使用less样式,组件使用全局样式文件中定义的变量操作
Oct 21 Javascript
探索node之事件循环的实现
Oct 30 Javascript
electron demo项目npm install安装失败的解决方法
Feb 06 #Javascript
详解React开发必不可少的eslint配置
Feb 05 #Javascript
详解js的作用域、预解析机制
Feb 05 #Javascript
Vue使用枚举类型实现HTML下拉框步骤详解
Feb 05 #Javascript
jQuery实现动态显示select下拉列表数据的方法
Feb 05 #jQuery
详解vue静态资源打包中的坑与解决方案
Feb 05 #Javascript
理解Koa2中的async&await的用法
Feb 05 #Javascript
You might like
linux下使用ThinkPHP需要注意大小写导致的问题
2011/08/02 PHP
php实现utf-8转unicode函数分享
2015/01/06 PHP
PHP图片加水印实现方法
2016/05/06 PHP
jQuery下实现等待指定元素加载完毕(可改成纯js版)
2013/07/11 Javascript
jquery实现预览提交的表单代码分享
2014/05/21 Javascript
JavaScript编程中容易出BUG的几点小知识
2015/01/31 Javascript
jQuery图片轮播实现并封装(一)
2016/12/03 Javascript
javascript 跨域问题以及解决办法
2017/07/17 Javascript
JS自定义函数实现时间戳转换成date的方法示例
2017/08/27 Javascript
js装饰设计模式学习心得
2018/02/17 Javascript
值得收藏的八个常用的js正则表达式
2018/10/19 Javascript
JavaScript继承与聚合实例详解
2019/01/22 Javascript
es6函数中的作用域实例分析
2020/04/18 Javascript
使用JS实现鼠标放上图片进行放大离开实现缩小功能
2021/01/27 Javascript
[36:33]Ti4 循环赛第四日 附加赛NEWBEE vs Mouz
2014/07/13 DOTA
RC4文件加密的python实现方法
2015/06/30 Python
Python使用遗传算法解决最大流问题
2018/01/29 Python
Django权限机制实现代码详解
2018/02/05 Python
对python3标准库httpclient的使用详解
2018/12/18 Python
Python基于Twilio及腾讯云实现国际国内短信接口
2020/06/18 Python
css3实现简单的白云飘动背景特效
2020/10/28 HTML / CSS
HTML5 通过Vedio标签实现视频循环播放的示例代码
2020/08/05 HTML / CSS
美国零售商店:Blue&Cream
2017/04/07 全球购物
FC-Moto瑞典:欧洲最大的摩托车服装和头盔商店之一
2018/11/27 全球购物
设计模式的基本要素是什么
2014/04/21 面试题
高中生学习生活的自我评价
2013/10/09 职场文书
应届生煤化工求职信
2013/10/21 职场文书
成品仓管员工作职责
2013/12/29 职场文书
个人委托书格式
2014/04/04 职场文书
爱国主义演讲稿
2014/05/07 职场文书
2015年乡镇流动人口工作总结
2015/05/12 职场文书
治理商业贿赂工作总结
2015/08/10 职场文书
公安纪律作风整顿心得体会
2016/01/23 职场文书
MySQL 覆盖索引的优点
2021/05/19 MySQL
Python如何识别银行卡卡号?
2021/06/10 Python
sql时间段切分实现每隔x分钟出一份高速门架车流量
2022/02/28 SQL Server