美文网首页
Vue3(五)vuex4 & vue-router4

Vue3(五)vuex4 & vue-router4

作者: 云瑶糖糖 | 来源:发表于2022-01-09 13:46 被阅读0次

1. 创建router对象

// createRouter方法,用于创建路由器对象
// createWebHashHistory方法,用于生成hash模式的路由,路由地址中包含一个#
// createWebHistory方法,用于生成history模式的路由
import {createRouter,createWebHashHistory} from 'vue-router'

// 创建当前项目中的路由器对象
let router = createRouter({
    //定义路由模式
    history:createWebHashHistory(),
    //定义具体的路由信息
    routes:[
        //每一条路由信息,配置一个对象
        {
            path:'/',
            name:'home',
            component:()=>import('../views/Home.vue')
        },
        {
            path:'/store',
            name:'store',
            component:()=>import('../views/Store.vue')
        },
        {
            path:'/list/:id',
            props:true,
            name:'list',
            component:()=>import('../views/List.vue')
        },
        {
            path:'/news',
            name:'news',
            component:()=>import('../views/News.vue')
        },
        {
            path:'/page1',
            name:'page1',
            component:()=>import('../views/Page1.vue')
        },
        {
            // 注意:不可以写通配符*
            // path:'*',
            path:'/:pathMatch(.*)*',
            name:'error404',
            component:()=>import('../views/Error404.vue')
        }
    ]
})

export default router

2. 使用router

//useRouter方法,返回当前项目中的路由器对象
//useRoute方法,返回当前路由信息对象
import {useRouter,useRoute} from 'vue-router'
//返回当前项目中的路由器对象
let $router = useRouter()
//获取当前路由信息
let $route = useRoute()
//通过props,也能获取都路由参数
props:['id']
//监听路由参数id
watch(()=>$route.params.id,(nval)=>{
    //清空数组
    showList.splice(0)
    //向数组中添加最新的数据
    showList.push(...list.filter(r=>r.typeId==$route.params.id))
},{
    //一上来,先执行一次
    immediate:true
})

3. 创建store对象

// 从vuex中导入createStore方法,该方法,用于创建全局状态管理对象
import { createStore } from 'vuex'
// 导入汽车模块
import car from './modules/car.js'
// 创建一个全局状态管理对象
let store = createStore({
    //定义状态
    state:{
        firstName:'张',
        lastName:'三'
    },
    //定义围绕状态的计算属性
    getters:{
        fullName(state){
            return state.firstName+'.'+state.lastName
        }
    },
    //定义同步方法
    mutations:{
        updateFirstName(state,val){
            state.firstName = val
        },
        updateLastName(state,val){
            state.lastName = val
        }
    },
    //定义异步方法
    actions:{
        updateFirstName(store,val){
            setTimeout(() => {
                store.commit('updateFirstName',val)
            }, 1000);
        },
        updateLastName(store,val){
            setTimeout(() => {
                store.commit('updateLastName',val)
            }, 1000);
        }
    },
    //模块
    modules:{
       car
    }
})

//导出全局状态管理对象
export default store

4. 使用store

//useStore方法,返回当前项目中的全局状态管理对象
import { useStore } from "vuex";
// 获取全局状态管理对象
let $store = useStore();
let firstName = computed(() => {
    return $store.state.firstName;
});
let lastName = computed(() => {
    return $store.state.lastName;
});
let fullName = computed(() => {
    return $store.getters.fullName;
});
let carName = computed(() => {
    return $store.state.car.carName;
});
let address = computed(() => {
    return $store.state.car.address;
});
let carInfo = computed(() => {
    return $store.getters["car/carInfo"];
});
function updateFirstName() {
    //调用mutations里面的方法,修改姓
    $store.commit("updateFirstName", "李");
}
function updateLastName() {
    //调用actions里面的方法,修改名
    $store.dispatch("updateLastName", "四");
}
function updateCarName() {
    //调用mutations里面的方法,修改车名
    $store.commit("car/updateCarName", "宾利");
}
function updateCarAddress() {
    //调用actions里面的方法,修改地址
    $store.dispatch("car/updateCarAddress", "英国");
}

5. 注册

// 导入当前项目中创建的全局状态管理对象
import store from './store'
// 导入当前项目中创建的路由器对象
import router from './router'
// 使用createApp方法创建一个Vue实例,该方法的参数是App组件,表示渲染App组件
// use方法,用于给当前vue实例添加功能
// mount方法,用于将渲染后的内容,挂载到指定的容器中
createApp(App).use(store).use(router).mount('#app')

相关文章

  • vue安装veux

    现在使用npm i 会默认安装vuex4,vuex4只适用于vue3,如果使用的vue环境是vue3,安装vuex...

  • Vue3(五)vuex4 & vue-router4

    1. 创建router对象 2. 使用router 3. 创建store对象 4. 使用store 5. 注册

  • vite安装 vuex4和vue-router4

    安装 vuex4和vue-router4 使用 创建文件src/router/index.js创建文件 src/s...

  • Vue3——vue-router4 & vuex4

    一、vue-router4 vue-router[https://next.router.vuejs.org/zh...

  • pinia与vuex对比

    Vue3 中使用 Vuex的话需要使用Vuex4,并且存在很大缺陷,所以在 Componsition API诞生之...

  • 2.Vue router与登陆功能

    0.开始之前 vue2和vue-router3版本,vue3和vue-router4版本对应,这会省下很多麻烦的事...

  • vue2 vuex的使用

    vuex在vue2中的使用与在vue3中不同,首先,需要安装vuex3而不是vuex4,然后,需要在全局中进行定义...

  • VUE3(五)vue路由vue-router4

    使用vue-router,这里特别说明一下,我这里记录的是vue-router文件的编写。及在页面中的使用。 我的...

  • Vue3 + Vuex4 构建点餐页面

    前言 前进!前进!不择手段地前进!! 距离Vue3.0 beta 发布已经过了半个多月了。本来这个东西上个月就应该...

  • 助你上手Vue3全家桶之VueX4教程

    1,前言 这些内容是博主在学习过程中记录下来的,有一些不重要的点就跳过了,需要时自行查询文档,4.0对比3.0,区...

网友评论

      本文标题:Vue3(五)vuex4 & vue-router4

      本文链接:https://www.haomeiwen.com/subject/abbqcrtx.html