IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue3.0,vue-router的简单使用 -> 正文阅读

[JavaScript知识库]vue3.0,vue-router的简单使用

createWebHistory路由模式路径不带#号(生产环境下不能直接访问项目,需要nginx转发)
createWebHashHistory路由模式路径带#号

/* router/index.js */
import { createRouter, createWebHashHistory } from 'vue-router'
import Home from '../views/Home.vue'

const routes = [
  {
    path: '/',
    name: 'Home',
    component: Home,
    beforeEach (to, from, next) {
		//  单独给某个组件加守卫也是没变
    },
    afterEach (to, from, next) {
      	//  
    }
  },
  {
    path: '/about',
    name: 'About',
    // route level code-splitting
    // this generates a separate chunk (about.[hash].js) for this route
    // which is lazy-loaded when the route is visited.
    component: () => import(/* webpackChunkName: "about" */ '../views/About.vue')
  }
]

const router = createRouter({
  history: createWebHashHistory(), // 这要改模式的话在上面引入createWebHistory,这也用它
  routes
})
// 可以动态添加路由
const home = () => import('../views/Home.vue')
const obj = { name: 'test', path: '/test', component: home }
router.addRoute(obj)

// 这的路由守卫还是和vue2.x 一样的
router.beforeEach((to, from, next) => {
  next()
})

export default router

在home.vue中使用路由

<script>
// 但是这个就没有包括beforeRouteLeave了
import { useRouter, useRoute, onBeforeRouteLeave, onBeforeRouteUpdate } from 'vue-router'
import { ref } from 'vue'
export default {
  name: 'Home',
  setup () {
    const router = useRouter() //  相当于this.$router
    const route = useRoute()  //  相当于this.$route
	const num = ref(0)
	onBeforeRouteUpdate((to, from) => { //  当前组件路由改变后,进行触发
      console.log('update')
    })
    onBeforeRouteLeave((to, from) => { //  离开当前的组件,触发
      console.log('leave')
    })
    return {
    	num
    }
  },
  beforeRouteEnter (to, from, next) {
     // ...因为兼容2.x所以这些也是可以用的,不过跟setup中的会有重复
  },
  beforeRouteLeave (to, from, next) {
    // ...
  }
}
</script>

除此之外:

//  使用方法传递参数这些都与2.x一样
    <router-link to="/">Home</router-link> |
    <router-link to="/about">About</router-link>
    <router-view/>
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:16:14  更:2022-04-01 23:20:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:21:44-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码