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知识库 -> Vue中的路由 -> 正文阅读

[JavaScript知识库]Vue中的路由

1.相关理解

1.1 vue-router的理解

? ? ? ? vue的一个插件库,专门用来实现SPA应用

1.2 对SPA应用的理解

  1. 但也Web应用
  2. 整个应用只有一个完整的页面
  3. 点击页面中的导航链接不会刷新页面(而类似于a标签则会默认刷新页面),指挥做页面的局部更新
  4. 数据需要通过ajax请求来获取

1.3 路由的理解

路由

  1. 理解:一个路由(route)就是一组映射关系(key-value),多个路由需要看路由器(router)进行管理
  2. 前端路由:key是路径,value是路由组件

基本使用

  1. 安装vue-router,命令:npm i vue-router
  2. 应用插件:Vue.use(VueRouter)
  3. 编写路由配置
import Vue from 'vue'
//引入vueRouter
import VueRouter from 'vue-router'
import Home from '../views/Home.vue'
import About from '../views/About.vue.vue'

Vue.use(VueRouter)

const routes = [
  {
    path: '/',
    name: 'Home',
    component: Home
  },
  {
    path: '/about',
    name: 'About',
    component: About

  }
]
//创建router示例对象,去管理一组一组的路由规则
const router = new VueRouter({
  routes
})

//暴露router
export default router

几个注意点

  1. 路由组件通常放在pages文件夹下,一般组件通常放在componnets文件夹下
  2. 通过切换,“隐藏”了的路由组件,默认是被销毁掉的,需要的时候再去挂载
  3. 每个路由组件都有自己的$route属性,里面存储着自己的路由信息
  4. 整个应用之只有一个router,可以通过组件的$router属性获取到。

使用

  1. 配置路由
import Vue from 'vue'
import VueRouter from 'vue-router'
import Home from '../views/Home.vue'
import About from '../views/About.vue'
import New from '../views/News.vue'


Vue.use(VueRouter)

const routes = [{
    path: '/',
    name: 'Home',
    component: Home,
  },
  {
    path: '/about',
    name: 'About',
    component: About,
    children: [{//通过children配置子级路由
      path: 'news',//此处不要写成:/news
      component:News
    }]
  }
]

const router = new VueRouter({
  routes
})

export default router

?2.显示路由

?3.跳转的时候需要写完整的路径

<router-link to="/about/news">news</router-link>

?路由传递参数(两种方式)

  • About路由组件页面
<template>
  <div class="about">
<!-- 向news路由传递参数-->
    <router-link to="/about/news">news</router-link>|
    <ul>
      <li v-for="m in list" :key="m.id">
        <router-link :to="{
          path:'/about/news',
          query:{
            id:m.id,
            name:m.name
          }

        }">{{m.name}}</router-link>
      </li>
    </ul>
    <router-view />
  </div>
</template>
<script>
export default {
  data() {
    return {
      list: [
        { id: 1, name: "haung" },
        { id: 2, name: "xu" },
        { id: 3, name: "hu" }
      ]
    };
  }
};
</script>
  • ?News路由组件页面
<template>
  <div>
    <ul>
      <li>hi:{{this.$route.query.id}}我是{{this.$route.query.name}}</li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {};
  },
  mounted(){
      console.log(this.$route)
  }
};
</script>

<style>
</style>
  • 结果

?简化路由跳转的路径

  • 之前我们在<router-link>中携带的路径是完整的path路径,接下我们可以为路由定义name,

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-30 15:31:56  更:2021-11-30 15:34:24 
 
开发: 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/6 13:32:08-

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