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 相关文章推荐
myFocus slide3D v1.1.0 使用方法与下载
Jan 12 Javascript
js导出table到excel同时兼容FF和IE示例
Sep 03 Javascript
jquery批量设置属性readonly和disabled的方法
Jan 24 Javascript
jQuery 获取/设置/删除DOM元素的属性以a元素为例
May 23 Javascript
教你用jquery实现iframe自适应高度
Jun 11 Javascript
JavaScript中的关联数组问题
Mar 04 Javascript
Javascript中的arguments与重载介绍
Mar 15 Javascript
一个php+js实时显示时间问题
Oct 12 Javascript
JavaScript操作表单实例讲解(上)
Jun 20 Javascript
bootstrap模态框示例代码分享
May 17 Javascript
通过button将form表单的数据提交到action层的实例
Sep 08 Javascript
vue+element实现表格新增、编辑、删除功能
May 28 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语言中global和$GLOBALS[]的分析 之二
2012/02/02 PHP
解决安装WampServer时提示缺少msvcr110.dll文件的问题
2017/07/09 PHP
PHP实现的用户注册表单验证功能简单示例
2019/02/25 PHP
浅谈laravel5.5 belongsToMany自身的正确用法
2019/10/17 PHP
常见的5个PHP编码小陋习以及优化实例讲解
2021/02/27 PHP
js 获取中文拼音,Select自动匹配字母获取值的代码
2009/09/23 Javascript
基于JQuery框架的AJAX实例代码
2009/11/03 Javascript
Jquery中删除元素的实现代码
2011/12/29 Javascript
JavaScript中使用typeof运算符需要注意的几个坑
2014/11/08 Javascript
JS实现点击按钮后框架内载入不同网页的方法
2015/05/05 Javascript
js实现二级菜单渐隐显示
2015/11/03 Javascript
JS清除文本框内容离开在恢复及鼠标离开文本框时触发js的方法
2016/01/12 Javascript
老生常谈遮罩层 滚动条的问题
2016/04/29 Javascript
深入理解Angularjs中的$resource服务
2016/12/31 Javascript
Nodejs实现短信验证码功能
2017/02/09 NodeJs
js指定步长实现单方向匀速运动
2017/07/17 Javascript
Node.js中的child_process模块详解
2018/06/08 Javascript
微信小程序项目总结之点赞 删除列表 分享功能
2018/06/25 Javascript
浅析vue中的MVVM实现原理
2019/03/04 Javascript
浅析JavaScript异步代码优化
2019/03/18 Javascript
有关wxpython pyqt内存占用问题分析
2014/06/09 Python
简介二分查找算法与相关的Python实现示例
2015/08/26 Python
python导入时小括号大作用
2017/01/10 Python
pytorch 把MNIST数据集转换成图片和txt的方法
2018/05/20 Python
浅谈python连续赋值可能引发的错误
2018/11/10 Python
Python转换时间的图文方法
2019/07/01 Python
Python用字典构建多级菜单功能
2019/07/11 Python
EMPHASIS艾斐诗官网:周生生旗下原创精品珠宝品牌
2020/12/17 全球购物
当x.equals(y)等于true时,x.hashCode()与y.hashCode()可以不相等,这句话对不对
2015/05/02 面试题
护理专科自荐书范文
2014/02/18 职场文书
奥巴马竞选演讲稿
2014/05/15 职场文书
普宁寺导游词
2015/02/04 职场文书
雷锋观后感
2015/06/10 职场文书
学校团代会开幕词
2016/03/04 职场文书
七年级作文之环保作文
2019/10/17 职场文书
详解Python生成器和基于生成器的协程
2021/06/03 Python