Vue Vue-route (4)

Vue 漸進式JavaScript 框架 基于Vue2的學習筆記 -?Vue-route?編程式導航和幾種路由

?

目錄

編程式導航?

詳情組件

創建組件

設置路由

電影列表

傳參

另一種方式

動態路由

命名路由

別名

總結


編程式導航?

點擊電影列表 跳轉電影詳情

詳情組件

創建組件

在views中創建DetailView.vue組件頁面。

示例如下:

設置路由

在router/index.js中引入詳情頁面并設置詳情路由。

示例如下:

import Detail from '@/views/DetailView'Vue.use(VueRouter) // 注冊路由插件// 配置表
const routes = [{path: '/films',name: 'films',component: Films,children: [{path: '/films/nowplaying',component: NowPlaying},{path: '/films/comingsoon',component: ComingSoon},{path: '/films',redirect: '/films/nowplaying'}]},{path: '/detail',name: 'detail',component: Detail},

?

電影列表

在films/NowPlaying.vue頁面渲染電影列表。

示例如下:

<template><div>nowplaying<ul><li v-for="data in datalist" :key="data"><router-link to="/detail">{{data}}</router-link></li></ul></div>
</template>
<script>
export default {data () {return {datalist: ['春眠不覺曉', '處處聞啼鳥', '夜來風雨聲', '花落知多少']}}
}
</script>
傳參

設置跳轉,使用編程式導航。

示例如下:

<template><div>nowplaying<ul><!-- <li v-for="data in datalist" :key="data"><router-link to="/detail">{{data}}</router-link></li> --><li v-for="data in datalist" :key="data" @click="handleChangePage()">{{data}}</li></ul></div>
</template>
<script>
export default {data () {return {datalist: ['春眠不覺曉', '處處聞啼鳥', '夜來風雨聲', '花落知多少']}},methods: {handleChangePage () {// 編程式導航location.href = '#/detail'}}
}
</script>
另一種方式

另一種方式實現跳轉。示例如下:

methods: {handleChangePage () {// 編程式導航// location.href = '#/detail'this.$router.push('/detail')}}

?

動態路由

列表項有很多,但詳情只有一個,需要根據選擇id,渲染相應詳情。

所以需要傳遞相應id,故在連接中增加id參數。

示例如下:

<template><div>nowplaying<ul><!-- <li v-for="data in datalist" :key="data"><router-link to="/detail">{{data}}</router-link></li> --><li v-for="data in datalist" :key="data" @click="handleChangePage(data)">{{data}}</li></ul></div>
</template>
<script>
export default {data () {return {datalist: ['春眠不覺曉', '處處聞啼鳥', '夜來風雨聲', '花落知多少']}},methods: {handleChangePage (id) {// 編程式導航// location.href = '#/detail'this.$router.push(`/detail/${id}`)}}
}
</script>

?

動態路由配置

在router/index.js中修改原有的詳情路由。

示例如下:

{path: '/detail/:myid', // 動態路由name: 'detail',component: Detail}

接收參數

在詳情組件內獲取參數。

通過生命周期中的created函數在組件創建時獲取參數。

示例如下:

控制臺查看打印結果

?

修改獲取參數

示例如下:

<script>export default {created () {// 當前匹配的路由console.log('created', this.$route.params.myid)// axios 利用 id發請求到詳情接口,獲取詳情數據,布局頁面}
}
</script>

?

命名路由

對路由進行命名,就可以通過命名路由直接跳轉。

{path: '/detail/:id', // 動態路由name: 'detail', // 命名路由component: Detail},

命名路由跳轉

      // 1 通過路徑跳轉this.$router.push(`/detail/${id}`)// 2 通過命名路由跳轉this.$router.push({name: 'detail',params: {id}})

別名

路由a別名是b,當用戶訪問b時,URL會保持為b,但是路由匹配則為a,

就像用戶訪問a一樣。

路由配置,示例如下:

{path: '/cinemas',name: 'cinemas',alias: '/ci',component: Cinemas}

“別名”的功能讓你可以自由地將UI結構映射到任意的URL,

而不是受限于配置的嵌套路由結構。

總結

Vue 漸進式JavaScript 框架 基于Vue2的學習筆記 -?Vue-route?編程式導航和幾種路由

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/90723.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/90723.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/90723.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

存在兩個cuda環境,在conda中切換到另一個

進入 openmmlab 環境 conda activate openmmlab 設置環境變量為 CUDA 12.4&#xff08;只影響當前 shell 會話&#xff09; export PATH/usr/local/cuda-12.4/bin:PATHexportLDLIBRARYPATH/usr/local/cuda?12.4/lib64:PATH export LD_LIBRARY_PATH/usr/local/cuda-12.4/lib64:…

Django 視圖(View)

1. 視圖簡介 視圖負責接收 web 請求并返回 web 響應。視圖就是一個 python 函數,被定義在 views.py 中。響應可以是一張網頁的 HTML 內容、一個重定向、一個 404 錯誤等等。響應處理過程如下圖: 用戶在瀏覽器中輸入網址:www.demo.com/1/100Django 獲取網址信息,去除域名和端…

HarmonyOS基礎概念

一、OpenHarmony、HarmonyOS和Harmony NEXT區別OpenHarmony是由開放原子開源基金會&#xff08;OpenAtom Foundation&#xff09;孵化及運營的開源項目&#xff0c;開放原子開源基金會由華為、阿里、騰訊、百度、浪潮、招商銀行、360等十家互聯網企業共同發起組建。目標是面向全…

spark3 streaming 讀kafka寫es

1. 代碼 package data_import import org.apache.spark.sql.{DataFrame, Row, SparkSession, SaveMode} import org.apache.spark.sql.types.{ArrayType, DoubleType, LongType, StringType, StructField, StructType, TimestampType} import org.apache.spark.sql.functions._…

【跟著PMP學習項目管理】每日一練 - 3

1、你是一個建筑項目的項目經理。電工已經開始鋪設路線,此時客戶帶著一個變更請求來找你。他需要增加插座,你認為這會增加相關工作的成本。你要做的第一件事? A、拒絕做出變更,因為這會增加項目的成本并超出預算 B、參考項目管理計劃,查看是否應當處理這個變更 C、查閱…

CentOS 安裝 JDK+ NGINX+ Tomcat + Redis + MySQL搭建項目環境

目錄第一步&#xff1a;安裝JDK 1.8方法 1&#xff1a;安裝 Oracle JDK 1.8方法 2&#xff1a;安裝 OpenJDK 1.8第二步&#xff1a;使用yum安裝NGINX第三步&#xff1a;安裝Tomcat第四步&#xff1a;安裝Redis第五步&#xff1a;安裝MySQL第六步&#xff1a;MySQL版本兼容性問題…

如何設計一個登錄管理系統:單點登錄系統架構設計

關鍵詞&#xff1a;如何設計一個登錄管理系統、登錄系統架構、用戶認證、系統安全設計 &#x1f4cb; 目錄 開篇&#xff1a;為什么登錄系統這么重要&#xff1f;整體架構設計核心功能模塊安全設計要點技術實現細節性能優化策略總結與展望 開篇&#xff1a;為什么登錄系統這么…

論跡不論心

2025年7月11日&#xff0c;16~26℃&#xff0c;陰 緊急不緊急重要 備考ing 備課不重要 遇見&#xff1a;免費人格測試 | 16Personalities&#xff0c;下面是我的結果 INFJ分析與優化建議 User: Anonymous (隱藏) Created: 2025/7/11 23:38 Updated: 2025/7/11 23:43 Exported:…

【面板數據】省級泰爾指數及城鄉收入差距測算(1990-2024年)

對中國各地區1990-2024年的泰爾指數、城鄉收入差距進行測算。本文參考龍海明等&#xff08;2015&#xff09;&#xff0c;程名望、張家平&#xff08;2019&#xff09;的做法&#xff0c;采用泰爾指數測算城鄉收入差距。參考陳斌開、林毅夫&#xff08;2013&#xff09;的做法&…

http get和http post的區別

HTTP GET 和 HTTP POST 是兩種最常用的 HTTP 請求方法&#xff0c;它們在用途、數據傳輸方式、安全性等方面存在顯著差異。以下是它們的主要區別&#xff1a;1. 用途GET&#xff1a;主要用于請求從服務器獲取資源&#xff0c;比如獲取網頁內容、查詢數據庫等。GET 請求不應該用…

I2C集成電路總線

&#xff08;摘要&#xff1a;空閑時&#xff0c;時鐘線數據線都是高電平&#xff0c;主機發送數據前&#xff0c;要在時鐘為高電平時&#xff0c;把數據線從高電平拉低&#xff0c;數據發送采取高位先行&#xff0c;時鐘線低電平時可以修改數據線&#xff0c;時鐘線高電平時要…

為了安全應該使用非root用戶啟動nginx

nginx基線安全&#xff0c;修復步驟。主要是由于使用了root用戶啟動nginx。為了安全應該使用非root用戶啟動nginx一、檢查項和問題檢查項分類檢查項名稱身份鑒別檢查是否配置Nginx賬號鎖定策略。服務配置檢查Nginx進程啟動賬號。服務配置Nginx后端服務指定的Header隱藏狀態服務…

論文解析篇 | YOLOv12:以注意力機制為核心的實時目標檢測算法

前言&#xff1a;Hello大家好&#xff0c;我是小哥談。長期以來&#xff0c;改進YOLO框架的網絡架構一直至關重要&#xff0c;但盡管注意力機制在建模能力方面已被證明具有優越性&#xff0c;相關改進仍主要集中在基于卷積神經網絡&#xff08;CNN&#xff09;的方法上。這是因…

學習C++、QT---20(C++的常用的4種信號與槽、自定義信號與槽的講解)

每日一言相信自己&#xff0c;你比想象中更接近成功&#xff0c;繼續勇往直前吧&#xff01;那么我們開始用這4種方法進行信號與槽的通信第一種信號與槽的綁定方式我們將按鍵右鍵后轉到槽會自動跳轉到這個widget.h文件里面并自動生成了定義&#xff0c;我們要記住我們這個按鈕叫…

Anolis OS 23 架構支持家族新成員:Anolis OS 23.3 版本及 RISC-V 預覽版發布

自 Anolis OS 23 版本發布之始&#xff0c;龍蜥社區就一直致力于探索同源異構的發行版能力&#xff0c;從 Anolis OS 23.1 版本支持龍芯架構同源異構開始&#xff0c;社區就在持續不斷地尋找更多的異構可能性。 RISC-V 作為開放、模塊化、可擴展的指令集架構&#xff0c;正成為…

4萬億英偉達,憑什么?

CUDA正是英偉達所有神話的起點。它不是一個產品&#xff0c;而是一個生態系統。當越多的開發者使用CUDA&#xff0c;就會催生越多的基于CUDA的應用程序和框架&#xff1b;這些殺手級應用又會吸引更多的用戶和開發者投身于CUDA生態。這個正向飛輪一旦轉動起來&#xff0c;其產生…

Unity3D iOS閃退問題解決方案

前言 在Unity3D開發中解決iOS閃退問題需要系統性排查&#xff0c;以下是關鍵步驟和解決方案&#xff1a; 對惹&#xff0c;這里有一個游戲開發交流小組&#xff0c;希望大家可以點擊進來一起交流一下開發經驗呀&#xff01; 1. 獲取崩潰日志&#xff08;關鍵第一步&#xff…

嵌入式八股文之 GPIO

1. GPIO 的基本概念(1) 什么是 GPIO&#xff1f;GPIO 的中文意思是通用輸入輸出端口&#xff08;General Purpose Input/Output&#xff09;&#xff0c;是嵌入式系統中可編程控制的通用引腳&#xff0c;可通過軟件配置為輸入或輸出模式。&#xff08;背誦&#xff09;(2) 它的…

Umi-OCR 的 Docker安裝(win制作鏡像,Linux(Ubuntu Server 22.04)離線部署)

前置博客&#xff1a;Ubuntu-Server 22.04.4 詳細安裝圖文教程 wget命令在windows終端下不能使用的原因及解決辦法 在 Ubuntu 22.04 LTS 上離線安裝 Docker 手把手教你在Win11下安裝docker Umi-OCR 安裝docker時報錯&#xff1a;workstation服務啟動報錯。錯誤1075&#…

力扣242.有效的字母異位詞

給定兩個字符串 s 和 t &#xff0c;編寫一個函數來判斷 t 是否是 s 的 字母異位詞。示例 1:輸入: s "anagram", t "nagaram" 輸出: true示例 2:輸入: s "rat", t "car" 輸出: false提示:1 < s.length, t.length < 5 * 104s…