vue2和vue3的基础用法对比第二篇

Posted DDjans

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue2和vue3的基础用法对比第二篇相关的知识,希望对你有一定的参考价值。

关于路由的使用

vue2写法

import Vue from "vue"  //引入vue

import Router from \'vue-router\'  //引入路由

Vue.use(Router)  //使用路由
//实例化router并配置参数
let router = new Router({
  mode:"hash",//模式-分为hash与history,不写默认hash模式
  //路由具体配置
  routes:[
     {
      name:"home", //名称
      path:"/home", //地址  \'/\'代表根目录下,如不写就地址为父组件path加上自生path
      component: () => import(组件路径), //组件地址,此为路由懒加载写法
      children:[
        //子组件,子组件跟父组件写法一样,也可再套children
        {  
          name:"son", //名称
          path:"/son", //地址  \'/\'代表根目录下,如不写就地址为父组件path加上自生path
          component: () => import(组件路径), //组件地址
        }
      ]
     },
     //找不到路径的重定向
     {
          path:"*",
          redirect: {
                path: "/home"
       }
     }
  ]
})
export default router //导出路由

vue3写法

 //引入路由函数和路由模式函数
import { createRouter, createWebHashHistory/createWebHistory} from \'vue-router\'; 
//实例化router并配置参数
const router=createRouter({
    //模式为hash:createWebHashHistory(),模式为history:createWebHistory()
    history:createWebHashHistory()/createWebHistory(), 
 routes:[ 
     {
      name:"home", //名称
      path:"/home", //地址  \'/\'代表根目录下,如不写就地址为父组件path加上自生path
      component: () => import(组件路径), //组件地址,此为路由懒加载写法
      children:[
        //子组件,子组件跟父组件写法一样,也可再套children
        {  
          name:"son", //名称
          path:"/son", //地址  \'/\'代表根目录下,如不写就地址为父组件path加上自生path
          component: () => import(组件路径), //组件地址
        }
      ]
     },
     //找不到路径的重定向
     {
          path:"/:pathMatch(.*)",//要写成正则表达式的方式,不能写成*了
          redirect: {
                path: "/home"
       }
     }
  ]
})
 
export default router

 

对比

引用、实例化路由对象对比

import Vue from "vue";import Router from "vue-router";Vue.use("Router");new Router()  变成

import { createRouter, createWebHashHistory/createWebHistory} from \'vue-router\'; createRouter()

路由模式对比

mode:hash/history 变成 history:createWebHashHistory()/createWebHistory()

找不到路径的重定向对比

path:"*" 变成 path:"/:pathMatch(.*)"

基本用法没有改变,只在引入创建路由实例、路由模式、重定向的写法上有所调整

 

以上是关于vue2和vue3的基础用法对比第二篇的主要内容,如果未能解决你的问题,请参考以下文章

vue3 基础概念 (含与 vue2.6 的对比)

Vue2 和 Vue3 中的 watch 用法

「offer来了」从基础到进阶原理,从vue2到vue3,48个知识点保姆级带你巩固vuejs知识体系

「offer来了」从基础到进阶原理,从vue2到vue3,48个知识点保姆级带你巩固vuejs知识体系

vue2饿了吗之路第二篇:登录

Vue3的computed用法