如果你想修改接口,请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来达到播放视频的效果
相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!
推荐阅读:
实现五级地区点击后加载
vue构建一个自动建站项目
在Vue.JS中怎样使用echarts
下载本文