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 相关文章推荐
JS+ACTIVEX实现网页选择本地目录路径对话框
Mar 18 Javascript
JavaScript设计模式之策略模式实例
Oct 10 Javascript
JavaScript encodeURI 和encodeURIComponent
Dec 04 Javascript
详解Jquery实现ready和bind事件
Apr 14 Javascript
jQuery插件zTree实现的基本树与节点获取操作示例
Mar 08 Javascript
JavaScript 数据类型详解
Mar 13 Javascript
详解angular中通过$location获取路径(参数)的写法
Mar 21 Javascript
JS的Ajax与后端交互数据的实例
Aug 08 Javascript
JS栈stack类的实现与使用方法示例
Jan 31 Javascript
微信小程序 腾讯地图显示偏差问题解决
Jul 27 Javascript
解决$store.getters调用不执行的问题
Nov 08 Javascript
js实现表单项的全选、反选及删除操作示例
Jun 05 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实现验证码功能
2006/10/09 PHP
深入探讨:Nginx 502 Bad Gateway错误的解决方法
2013/06/03 PHP
php中smarty模板条件判断用法实例
2015/06/11 PHP
浅谈PHP各环境下的伪静态配置
2019/03/13 PHP
学习YUI.Ext 第六天--关于树TreePanel(Part 1)
2007/03/10 Javascript
Convert Seconds To Hours
2007/06/16 Javascript
基于jquery自定义图片热区效果
2012/07/21 Javascript
AngularJS基础知识笔记之表格
2015/05/10 Javascript
JavaScript实现自动消除按钮功能的方法
2015/08/05 Javascript
Node.js的项目构建工具Grunt的安装与配置教程
2016/05/12 Javascript
浅谈Javascript中的12种DOM节点类型
2016/08/19 Javascript
JavaScript闭包_动力节点Java学院整理
2017/06/27 Javascript
Angular.js中数组操作的方法教程
2017/07/31 Javascript
canvas+gif.js打造自己的数字雨头像的示例代码
2017/10/26 Javascript
ejsExcel模板在Vue.js项目中的实际运用
2018/01/27 Javascript
angularJs中orderBy筛选以及filter过滤数据的方法
2018/09/30 Javascript
Vue 使用iframe引用html页面实现vue和html页面方法的调用操作
2020/11/16 Javascript
el-table表头根据内容自适应完美解决表头错位和固定列错位
2021/01/07 Javascript
python实现保存网页到本地示例
2014/03/16 Python
python使用wxPython打开并播放wav文件的方法
2015/04/24 Python
Python输入二维数组方法
2018/04/13 Python
Python unittest模块用法实例分析
2018/05/25 Python
pandas分别写入excel的不同sheet方法
2018/12/11 Python
pycharm打开命令行或Terminal的方法
2019/01/16 Python
Python实现的排列组合、破解密码算法示例
2019/04/12 Python
调试Django时打印SQL语句的日志代码实例
2019/09/12 Python
使用python写一个自动浏览文章的脚本实例
2019/12/05 Python
python用pip install时安装失败的一系列问题及解决方法
2020/02/24 Python
django实现后台显示媒体文件
2020/04/07 Python
如何真正的了解python装饰器
2020/08/14 Python
StubHub哥伦比亚:购买和出售您的门票
2016/10/20 全球购物
职工运动会邀请函
2014/01/19 职场文书
内勤主管岗位职责
2014/04/03 职场文书
八项规定整改方案
2014/10/01 职场文书
56句经典英文座右铭
2019/08/09 职场文书
微软Win11 全新照片应用面向 Dev预览版推出 新版本上手体验图集
2022/09/23 数码科技