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 动态修改样式和层叠样式表代码
Apr 27 Javascript
javascript笔记 String类replace函数的一些事
Sep 22 Javascript
用JQUERY增删元素的代码
Feb 14 Javascript
eclipse导入jquery包后报错的解决方法
Feb 17 Javascript
jQuery each函数源码分析
May 25 Javascript
AngularJS基础 ng-mouseenter 指令示例代码
Aug 02 Javascript
微信小程序  audio音频播放详解及实例
Nov 02 Javascript
JS中的三个循环小结
Jun 20 Javascript
react-router4 嵌套路由的使用方法
Jul 24 Javascript
Vue+Vux项目实践完整代码
Nov 30 Javascript
javascript(基于jQuery)实现鼠标获取选中的文字示例【测试可用】
Oct 26 jQuery
three.js 实现露珠滴落动画效果的示例代码
Mar 01 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
PHP排序算法的复习和总结
2012/02/15 PHP
php使用正则验证中文
2016/04/06 PHP
Laravel + Elasticsearch 实现中文搜索的方法
2020/02/02 PHP
php实现断点续传大文件示例代码
2020/06/19 PHP
Javascript 类型转换方法
2010/10/24 Javascript
jquery form 加载数据示例
2014/04/21 Javascript
13 款最热门的 jQuery 图像 360 度旋转插件推荐
2014/12/09 Javascript
JavaScript实现为指定对象添加多个事件处理程序的方法
2015/04/17 Javascript
bootstrap modal弹出框的垂直居中
2016/12/14 Javascript
canvas实现探照灯效果
2017/02/07 Javascript
js实现瀑布流效果(自动生成新的内容)
2017/03/16 Javascript
ReactNative踩坑之配置调试端口的解决方法
2017/07/28 Javascript
addeventlistener监听scroll跟touch(实例讲解)
2017/08/04 Javascript
js实现QQ面板拖拽效果(慕课网DOM事件探秘)(全)
2017/09/19 Javascript
vue解决跨域路由冲突问题思路解析
2017/11/03 Javascript
jQuery实现的卷帘门滑入滑出效果【案例】
2019/02/18 jQuery
修改NPM全局模式的默认安装路径的方法
2020/12/15 Javascript
[01:13]DOTA2群星解读国服召集令 一起说出回归的理由
2013/07/17 DOTA
Python实现的最近最少使用算法
2015/07/10 Python
Python通过OpenCV的findContours获取轮廓并切割实例
2018/01/05 Python
python打造爬虫代理池过程解析
2019/08/15 Python
python 中Arduino串口传输数据到电脑并保存至excel表格
2019/10/14 Python
浅析PEP570新语法: 只接受位置参数
2019/10/15 Python
python3操作注册表的方法(Url protocol)
2020/02/05 Python
python Gabor滤波器讲解
2020/10/26 Python
Python 微信公众号文章爬取的示例代码
2020/11/30 Python
HTML5触摸事件演化tap事件介绍
2016/03/25 HTML / CSS
英国顶级家庭折扣店:The Works
2017/09/06 全球购物
JD Sports马来西亚:英国领先的运动鞋和运动服饰零售商
2018/03/13 全球购物
党风廉政承诺书
2014/03/27 职场文书
大学理论知识学习自我鉴定
2014/04/28 职场文书
有关爱国演讲稿
2014/05/07 职场文书
中学生爱国演讲稿
2014/09/05 职场文书
2015年社区卫生工作总结
2015/04/21 职场文书
2016年度先进班组事迹材料
2016/03/01 职场文书
go语言求任意类型切片的长度操作
2021/04/26 Golang