最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 19:39:45
文档

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

使用Vue仿制今日头条(详细教程):这篇文章主要介绍了Vue仿今日头条实例详解,并把相关代码做了说明,对此有兴趣的朋友参考下吧。前言vue也弄了一段时间了, 前段时间一直想用vue写个移动端,加之年底也不是很忙,于是前几天便着手开始弄了,到今天为止也算是勉强能看了因为也是纯粹的写写前端页面
推荐度:
导读使用Vue仿制今日头条(详细教程):这篇文章主要介绍了Vue仿今日头条实例详解,并把相关代码做了说明,对此有兴趣的朋友参考下吧。前言vue也弄了一段时间了, 前段时间一直想用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 进行打包处理,所有启动该项目时记得,先执行一次该脚本命令生成配置

  • 效果演示:

    几个常用的知识点

    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

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

    相关文章:

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

    在vue2.0中不同屏幕适配px与rem转换问题

    在Vue中如何实现带进度条的文件拖动上传功能

    文档

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

    使用Vue仿制今日头条(详细教程):这篇文章主要介绍了Vue仿今日头条实例详解,并把相关代码做了说明,对此有兴趣的朋友参考下吧。前言vue也弄了一段时间了, 前段时间一直想用vue写个移动端,加之年底也不是很忙,于是前几天便着手开始弄了,到今天为止也算是勉强能看了因为也是纯粹的写写前端页面
    推荐度:
    标签: 今日头条 VUE 用vue
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top