使用Vue仿制今日头条(详细教程)

这篇文章主要介绍了vue仿今日头条实例详解,并把相关代码做了说明,对此有兴趣的朋友参考下吧。

前言

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. 路由懒加载

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

登录后复制

  1. const _import_ = file => () => import('views/' + file + '.vue'){  path: '/development',  name: 'development',  component: _import_('development')}

登录后复制

2. 登陆拦截

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

  1. // 如:系统设置需要登陆{   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属性 来判断它做什么样的切换动画

  1. 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

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在vue中处理对象属性改变视图不更新问题?

在vue中处理对象属性改变视图不更新问题?

在vue中处理对象属性改变视图不更新问题?

以上就是使用Vue仿制今日头条(详细教程)的详细内容,更多请关注【创想鸟】其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

点点赞赏,手留余香

给TA打赏
共0人
还没有人赞赏,快来当第一个赞赏的人吧!
    编程技术

    React开发如何配置eslint

    2025-3-31 23:07:03

    编程技术

    JS中的单例模式实现对数据增删改查

    2025-3-31 23:07:20

    0 条回复 A文章作者 M管理员
    欢迎您,新朋友,感谢参与互动!
      暂无讨论,说说你的看法吧
    个人中心
    购物车
    优惠劵
    今日签到
    私信列表
    搜索