vue 仿今日头条_Vue仿今日头条实例详解_莺语_前端开发者

前言

因为也是纯粹的写写前端页面,所以数据方面用的是mock.

账号: vue-toutiao

密码: 123456

如果你想修改接口,请copy一份在修改

如果你想后台接口也自己开发的话。可以阅读我这篇博客 Vue +

技术栈:

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.

7. Easy Mock

代码实例:https://github.com/cd-dongzi/vue-project/tree/master/vue-toutiao

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值