zoukankan      html  css  js  c++  java
  • vue-x action document.title动态变化通过router.afterEach动态掉action

        import Vue from 'vue'
        import Vuex from 'vuex'
    
        Vue.use(Vuex)
    
        export default new Vuex.Store({
            state: {
                shopCart:'',
                mallId:"",
                phone:'',
                userInfo:'',
                title:"",
                order_no:'',
            },
            getters: {
    
            },
            mutations: {
                changeShopCart(state,shopCart){
                    state.shopCart=shopCart;
                },
                saveUserInfo(state,userInfo){
                    state.userInfo=userInfo;
                },
                saveMallId(state,mallId){
                    state.mallId=mallId
                },
                savePhone(state,phone){
                    state.phone=phone
                },
                saveItemIndex(state,itemIndex){
                    state.itemIndex=itemIndex
                },
                saveMyCustomer(state,customer){
                    state.customer=customer
                },
                saveMyGetCustomer(state,getCustomer){
                    state.getCustomer=getCustomer
                },
                saveAddressList(state,addressList){
                    state.addressList=addressList
                },
                saveSelectedItem(state,addressItem){
                    state.addressItem=addressItem
                },
                // saveDefaultData(state,defaultData){
                //     state.defaultData=defaultData
                // },
                saveOrderNo(state,order_no){
                    state.order_no=order_no
                }
            },
            actions: {
                changeTitle({commit}, title){
                   document.title = title
                },
            }
        })
    import Vue from 'vue'
    import VueRouter from 'vue-router'
    import Store from '../store'
    
    Vue.use(VueRouter)
    
    const routes = [{
            path: '/',
            component: (resolve) => require(['../pages/mall/mall.vue'], resolve),
            meta: {
                title: '点外卖',
            }
        },
        {
            path: '/order',
            component: (resolve) => require(['../pages/order/order.vue'], resolve),
            meta: {
                title: '订单详情',
            }
        },
        {
            path: '/orderDetail',
            component: (resolve) => require(['../pages/order/detailOrderPage.vue'], resolve),
            meta: {
                title: '订单详情',
            }
        },
        {
            path: '/orderWait',
            component: (resolve) => require(['../pages/order/waitToUse.vue'], resolve),
            meta: {
                title: '待使用',
            }
        },
        {
            path: '/orderList',
            name: 'orderList',
            component: (resolve) => require(['../pages/order/orderList.vue'], resolve),
            meta: {
                title: '订单列表详情',
            }
        },
        {
            path: '/addressList',
            name: 'addressList',
            component: (resolve) => require(['../pages/address/address-list.vue'], resolve),
            meta: {
                title: '地址详情',
            }
        },
        {
            path: '/newAddress',
            component: (resolve) => require(['../pages/address/new-address.vue'], resolve),
            meta: {
                title: '新增地址',
            }
        },
        {
            path: '/personal',
            component: (resolve) => require(['../pages/personal/personalPage.vue'], resolve),
            meta: {
                title: '个人中心',
            }
        },
        {
            path: '/binding',
            component: (resolve) => require(['../pages/binding/binding.vue'], resolve),
            meta: {
                title: '账户绑定',
            }
        },
        {
            path: '/accountManage',
            component: (resolve) => require(['../pages/binding/accountManage.vue'], resolve),
            meta: {
                title: '账户管理',
            }
        },
        {
            path: '/newAccount',
            component: (resolve) => require(['../pages/binding/newAccount.vue'], resolve),
            meta: {
                title: '设置新手机号',
            }
        },
    ]
    
    // 路由配置
    const router = new VueRouter({
        routes
    })
    
    // router.beforeEach((to, from, next) => {
    //     next()
    // })
    //
    router.afterEach((to) => {
        Store.dispatch('changeTitle', to.meta.title)
    })
    
    export default router
  • 相关阅读:
    springMVC 返回json 忽略类中属性的注解
    MySQL中函数CONCAT及GROUP_CONCAT
    ArrayList转成HashMap再转成LinkedHashMap 自己的解决方案
    easyui datebox 设置不可编辑
    js或jquery如何获取父级、子级、兄弟元素(包括祖级、孙级等)
    关于js中空值比较和传值的问题
    Tomcat报错:Failed to start component [StandardEngine[Catalina].StandardHost[localhost]]
    JQuery 阻止js事件冒泡 阻止浏览器默认操作
    visualstudio2017 +EF+Mysql生成实体数据模型闪退
    MVC错误:查询的结果不能枚举多次
  • 原文地址:https://www.cnblogs.com/MR-cui/p/8655735.html
Copyright © 2011-2022 走看看