亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3中關(guān)于路由規(guī)則的props配置方式

 更新時間:2024年03月18日 10:14:41   作者:小饅頭學python  
這篇文章主要介紹了Vue3中關(guān)于路由規(guī)則的props配置方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

簡單介紹

在 Vue3 中,使用 Vue Router 進行路由管理時,可以通過配置路由規(guī)則的 props 屬性,將路由參數(shù)傳遞給組件。

這樣可以使路由參數(shù)直接作為組件的屬性,在組件中使用更加方便

在路由配置中使用 props

在定義路由規(guī)則時,可以通過設置 props 屬性來指定如何將路由參數(shù)傳遞給組件。

props 可以是一個布爾值、對象或函數(shù)

props的第一種寫法

我們來回顧一下上節(jié)對于Detail.vue中的代碼,使用的是params參數(shù)

<template>
    <ul class="news-list">
      <li>編號:{{ route.params.id }}</li>
      <li>標題:{{ route.params.title }}</li>
      <li>內(nèi)容:{{ route.params.content }}</li>
    </ul>
  </template>
    
  <script setup lang="ts" name="About">
  import { useRoute } from 'vue-router'
  let route = useRoute()
  </script>
  
  <style scoped>
    .news-list {
      list-style: none;
      padding-left: 20px;
    }
  
    .news-list>li {
      line-height: 30px;
    }
  </style>

如果我們不想在模版中寫route的話,我們需要使用torefs進行結(jié)構(gòu),下面的博客或許會幫助你

Vue3 toRefs和toRef在reactive中的一些應用

修改后的代碼如下,和之前的運行結(jié)果是一樣的

<template>
    <ul class="news-list">
      <li>編號:{{ params.id }}</li>
      <li>標題:{{ params.title }}</li>
      <li>內(nèi)容:{{ params.content }}</li>
    </ul>
  </template>
    
  <script setup lang="ts" name="About">
  import { toRefs } from 'vue'
  import { useRoute } from 'vue-router'
  let route = useRoute()
  let {params} = toRefs(route)
  </script>
  
  <style scoped>
    .news-list {
      list-style: none;
      padding-left: 20px;
    }
  
    .news-list>li {
      line-height: 30px;
    }
  </style>

這樣我們就可以省略了route,但是如果我們還想省略params呢,該怎么做

接下來我們引入props,來實現(xiàn)無需寫route和params

首先我們需要在index.ts中加上一句

再之后我們就在Detail.vue的ts里面加上一句就可以完美的實現(xiàn)之前的代碼了

 <script setup lang="ts" name="About">
 defineProps(['id','title','content'])
  </script>

完整代碼如下

<template>
    <ul class="news-list">
      <li>編號:{{ id }}</li>
      <li>標題:{{ title }}</li>
      <li>內(nèi)容:{{ content }}</li>
    </ul>
  </template>
    
  <script setup lang="ts" name="About">
 defineProps(['id','title','content'])
  </script>
  
  <style scoped>
    .news-list {
      list-style: none;
      padding-left: 20px;
    }
  
    .news-list>li {
      line-height: 30px;
    }
  </style>

上面僅僅是第一種寫法,大概意思就是將路由收到的所有params參數(shù)作為props傳給路由組件

props的第二種寫法

這種寫法是使用函數(shù)的形式

props(route){
            return route.params
          }

當然也是可以使用query的

props(route){
            return route.query
          }

但是使用query別忘了修改點地方

事實證明,也是可以實現(xiàn)的

props的第三種寫法

第三種寫法是對象寫法

  • 對象寫法相對于函數(shù)寫法更加靜態(tài),因為它直接將固定的值傳遞給組件屬性,無法根據(jù)路由的動態(tài)變化來改變傳遞的值。
  • 而函數(shù)寫法可以根據(jù)需要動態(tài)地返回不同的屬性值,更加靈活。
  • 因此,在需要根據(jù)路由動態(tài)變化屬性值的情況下,使用函數(shù)寫法更加合適;而在屬性值固定的情況下,使用對象寫法可能更為簡潔明了

就是較為固定,如果想動態(tài)還是函數(shù)比較好

總結(jié)

通過合理配置路由規(guī)則的 props 屬性,可以使路由參數(shù)更加靈活地傳遞給組件。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue下載不同文件的幾種方式總結(jié)

    Vue下載不同文件的幾種方式總結(jié)

    在Vue項目中實現(xiàn)文件下載有多種方式,包括使用window.open、<a>標簽、axios、FetchAPI、自定義$download方法以及創(chuàng)建a標簽等,每種方法都有其適用場景,開發(fā)者可以根據(jù)項目需求選擇最合適的方式
    2025-01-01
  • Jenkins?Sidebar?Link插件實現(xiàn)添加側(cè)邊欄功能詳解

    Jenkins?Sidebar?Link插件實現(xiàn)添加側(cè)邊欄功能詳解

    這篇文章主要介紹了vue框架實現(xiàn)添加側(cè)邊欄,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue的el-select綁定的值無法選中el-option問題及解決

    vue的el-select綁定的值無法選中el-option問題及解決

    這篇文章主要介紹了vue的el-select綁定的值無法選中el-option問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue使用input封裝上傳文件圖片全局組件的示例代碼

    vue使用input封裝上傳文件圖片全局組件的示例代碼

    實際開發(fā)過程中,我們經(jīng)常遇見需要上傳文件圖片功能,可以封裝一個全局組件來調(diào)用,這篇文章給大家介紹vue使用input封裝上傳文件圖片全局組件,感興趣的朋友跟隨小編一起看看吧
    2023-11-11
  • Vue表單驗證插件Vue Validator使用方法詳解

    Vue表單驗證插件Vue Validator使用方法詳解

    這篇文章主要為大家詳細介紹了Vue表單驗證插件Vue Validator使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • vue.js實現(xiàn)標簽頁切換效果

    vue.js實現(xiàn)標簽頁切換效果

    這篇文章主要介紹了vue.js實現(xiàn)標簽頁切換效果,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06
  • vue添加錨點,實現(xiàn)滾動頁面時錨點添加相應的class操作

    vue添加錨點,實現(xiàn)滾動頁面時錨點添加相應的class操作

    這篇文章主要介紹了vue添加錨點,實現(xiàn)滾動頁面時錨點添加相應的class操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • Vue?內(nèi)置指令梳理總結(jié)

    Vue?內(nèi)置指令梳理總結(jié)

    這篇文章主要介紹了Vue?內(nèi)置指令梳理總結(jié),文章首先從v-text指令展開內(nèi)容介紹,具有一定的知識性參考價值,需要的小伙伴可以參考一下
    2022-05-05
  • vue3中的ref、reactive問題解析

    vue3中的ref、reactive問題解析

    ref 和 reactive都是vue3推出的針對組合式設計的聲明響應式狀態(tài)的API,兩者在使用之前都要先進行引入,本文通過實例代碼詳解vue3中的ref、reactive問題,感興趣的朋友一起看看吧
    2024-03-03
  • vue+elementUi 實現(xiàn)密碼顯示/隱藏+小圖標變化功能

    vue+elementUi 實現(xiàn)密碼顯示/隱藏+小圖標變化功能

    這篇文章主要介紹了vue+elementUi 實現(xiàn)密碼顯示/隱藏+小圖標變化功能,需本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01

最新評論