Vue-cli搭建项目

2018-09-28  本文已影响0人  良人不良

Vue脚手架

基本环境
vue-cli来构建项目
简单说明下脚手架每个目录的作用:
路由文件配置
!!第一种方法
import Vue from 'vue'     
import Router from 'vue-router';

Vue.use(Router)   //初始化路由

const Foo = { template: '<div>foo</div>' };  //Foo小组件
const Bar = { template: '<div>bar</div>' };  //Bar小组件

//定义路由
const routes = [
        { path: '/foo', component: Foo },
        { path: '/bar', component: Bar }
]
//路由的安装,使用路由
const router = new Router({
    method:'history',   //选取模式,历史模式和哈希模式
    routes
})
export default router;    //导出


!!第二种方法
import Vue from 'vue';     
import Router from 'vue-router';

import Header from '文件路径';   //引入Header组件
import Nav from '文件路径';   //引入Nav组件

初始化路由
Vue.use(Router);

定义路由和路由的安装
const router = new Router({
    routes: [                 //配置路由
        {
            path: '/header',
            component: Header,//在一级路由的template标签中插入二级路由的<router-view>标签
            children: [
                {
                    path: 'child',      //二级路由  注意这里没有/ ,否则会被认为是绝对路径,不写是相对路径
                    component: Child    //路由需要的组件
                }
            ],
            redirect: '/header/child'   //设置进入header路由后,默认跳转到/header/child这个二级路由
        },
        {
            path: '/nav/:id',      //访问路径,路由名称   动态路由
            component: Nav     //路由需要的组件
        },
        {
            path: '/*',
            redirect: '/header'  //重定向到‘header’路由
        }
    ]
    scrollBehavior(to, from, savedPosition) {
        return { x: 0, y: 0}   //滑动条自动到最顶端
    }
})
export default router;
状态管理文件配置
import Vue from 'vue';
import Vuex from 'vuex';

Vue.use(Vuex);

var store = new Vuex.Store({
    //定义公共状态
    state: {
        isNavShow: false,
        setHeaderName: '卖座电影',
        setCity: '大连'
    },
    actions:{
        //用于异步操作,方法名也都是大写的
         CHANGE_COUNT_ACT(context,payload){
            setTimeout(()=>{
                //context 执行上下文,相当于this,这里是$store
                context.commit('CHANG_COUNT',payload)
            },1000)
        }
    },
    mutations: {   //同步的周期
        //方法名字必须为大写
        //用于同步操作,不能进行异步操作,否则devtools检测不到
        CHANGE_NAV(state, payload) {    //第一个参数为共享状态,第二个参数是其它组件传递的数据
            state.isNavShow = payload;
        },
        CHANGE_HEADERNAME(state, payload) {
            state.setHeaderName = payload;
        },
        CHANGE_CITY(state, payload) {
            state.setCity = payload;
        }
    }
})

//提供对外接口
export default store;

上一篇 下一篇

猜你喜欢

热点阅读