欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue 3 動態(tài) ref 的使用方式以表格為列

 更新時間:2025年05月21日 09:12:07   作者:娃哈哈哈哈呀  
我正在開發(fā)的項目中,有一個表格組件,其中一列是分鏡描述,需要支持視頻上傳功能,下面給大家介紹Vue 3動態(tài)ref的使用方式以表格為列給大家詳細講解,感興趣的朋友一起看看吧

Vue 3 動態(tài) ref 的使用方式(表格)

一、問題描述

先給大家簡單介紹一下問題背景。我正在開發(fā)的項目中,有一個表格組件,其中一列是分鏡描述,需要支持視頻上傳功能。用戶可以為每一行的分鏡描述上傳對應的視頻示例。然而,在實現(xiàn)過程中,出現(xiàn)了一個嚴重的問題:當表格有多行數(shù)據(jù)時,點擊某一行的本地上傳按鈕,選擇文件后,數(shù)據(jù)卻總是跑到最后一行。這顯然不符合預期,嚴重影響了用戶體驗和功能的正確性。

二、解決

1、創(chuàng)建了一個inputRefs對象來存儲input元素的引用: 

const shotVideInputRefs = ref<Record<string, HTMLInputElement>>({});

2、在模板中,通過以下方式綁定ref

  <input :key="row.id" :ref="(el) => (shotVideInputRefs[row.id] = el as HTMLInputElement)" type="file" @change="handleShotFileChange(row, $event)" />

3、觸發(fā)文件上傳對話框的方法:根據(jù)當前行的id來獲取對應的input引用并觸發(fā)點擊事件:

const triggerShotVideoInput = (rowId) => {
  if (shotVideInputRefs.value[rowId]) {
    shotVideInputRefs.value[rowId].click();
  }
};

擴展:vue Router(v3.x) 路由傳參的三種方式場景分析

推薦閱讀:

vue Router(v3.x) 路由傳參的三種方式場景分析

詳解vue-router傳參的兩種方式

vue Router(v3.x) 路由傳參的三種方式

vue 路由傳參的使用場景一般都是應用在父路由跳轉到子路由時,攜帶參數(shù)跳轉。傳參方式可劃分為 params 傳參和 query 傳參,而 params 傳參又可分為在 url 中顯示參數(shù)和不顯示參數(shù)兩種方式,這就是vue路由傳參的三種方式。

當然 ,這三種傳參方式只是針對vue Router V3版本的,V4版本的路由傳參會有些不同;V3版本經(jīng)常與vue2相配合使用;而V4版本則多和vue3配合使用;

一,params 傳參(顯示參數(shù))

這種方式vue router官網(wǎng)也叫 動態(tài)路由匹配

1,,首先需要在路由表中配置 冒號+參數(shù)(/user/:id

  	// 這是動態(tài)路由 加上:/:id
      {
        path: "/routers/:id",
        name: "Routers",
        meta: { title: "動態(tài)路由" },
        component: () => import("../views/routers/routers.vue")
      },

2,開始跳轉并傳參

jumpTo() {
      this.$router.push({ path: "/routers/123" });
    }

3,獲取動態(tài)路由參數(shù)

created(){
	console.log('獲取', this.$route.params); //{id: '123'}
}

當然,你也可以傳多個參數(shù),只不過需要在路由表中配置多個,如下:

在這里插入圖片描述

注意: 響應路由參數(shù)的變化

注意:當使用路由參數(shù)時,例如從 /user/foo 導航到 /user/bar,原來的組件實例會被復用。因為兩個路由都渲染同個組件,比起銷毀再創(chuàng)建,復用則顯得更加高效。不過,這也意味著組件的生命周期鉤子不會再被調用。

復用組件時,想對路由參數(shù)的變化作出響應的話,你可以簡單地 watch (監(jiān)測變化) $route 對象:

const User = {
  template: '...',
  watch: {
    $route(to, from) {
      // 對路由變化作出響應...
    }
  }
}

或者使用 2.2 中引入的 beforeRouteUpdate 導航守衛(wèi):

const User = {
  template: '...',
  beforeRouteUpdate(to, from, next) {
    // react to route changes...
    // don't forget to call next()
  }
}

二,params 傳參(不顯示參數(shù))

1,使用不顯示參數(shù)的方式,則不需要在進行配置路由表:

  	{
        path: "routers",
        name: "Routers",
        component: () => import("../views/routers/routers.vue")
      },

2,開始跳轉并傳參

注意:需要指定路由表中的 name與之相對應;

jumpTo() {
      this.$router.push({ name: "Routers", params:{ id:123 } });
    }

3,獲取參數(shù)

this.$route.params.id

注意:上述這種利用 params 不顯示 url 傳參的方式會導致在刷新頁面的時候,傳遞的值會丟失;需要謹慎使用。

三,query 傳參(顯示參數(shù))

這種傳參方式會把你的參數(shù)以問號拼接到路由上面;刷新頁面且路由不會丟失。

1,這種也不需要進行配置路由表:

  	{
        path: "routers",
        name: "Routers",
        component: () => import("../views/routers/routers.vue")
      },

2,開始跳轉并傳參

注意:需要與路由表中的 path屬性 與之相對應;

this.$router.push({ path:'/routers',  query:{	id:123 } })

3,獲取參數(shù)

this.$route.query.id

到此這篇關于vue Router(v3.x) 路由傳參的三種方式詳解的文章就介紹到這了,更多相關vue Router 路由傳參內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue使用el-table實現(xiàn)自適應列寬

    Vue使用el-table實現(xiàn)自適應列寬

    這篇文章主要為大家詳細介紹了Vue使用el-table實現(xiàn)自適應列寬,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • Vue中使用ECharts與v-if的問題和解決方案

    Vue中使用ECharts與v-if的問題和解決方案

    在Vue項目中使用v-if指令控制ECharts圖表顯示時,可能會遇到圖表無法正常渲染或顯示錯誤的問題,下面這篇文章主要介紹了Vue中使用ECharts與v-if的問題和解決方案,需要的朋友可以參考下
    2024-10-10
  • vue-cli2與vue-cli3在一臺電腦共存的實現(xiàn)方法

    vue-cli2與vue-cli3在一臺電腦共存的實現(xiàn)方法

    這篇文章主要介紹了vue-cli2與vue-cli3在一臺電腦共存的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • Vue.js上傳圖片到阿里云OSS存儲的方法示例

    Vue.js上傳圖片到阿里云OSS存儲的方法示例

    這篇文章主要介紹了Vue.js上傳圖片到阿里云OSS存儲的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • ruoyi-vue3 集成aj-captcha實現(xiàn)滑塊、文字點選驗證碼功能

    ruoyi-vue3 集成aj-captcha實現(xiàn)滑塊、文字點選驗證碼功能

    這篇文章主要介紹了 ruoyi-vue3 集成aj-captcha實現(xiàn)滑塊、文字點選驗證碼,本文基于后端RuoYi-Vue 3.8.7 和 前端 RuoYi-Vue3 3.8.7,集成以AJ-Captcha文字點選驗證碼為例,不需要鍵盤手動輸入,極大優(yōu)化了傳統(tǒng)驗證碼用戶體驗不佳的問題,感興趣的朋友一起看看吧
    2023-12-12
  • 詳解Vue中的自定義指令

    詳解Vue中的自定義指令

    這篇文章主要介紹了Vue中的自定義指令的相關資料,幫助大家更好的理解和學習vue框架,感興趣的朋友可以了解下
    2020-12-12
  • 使用Vue實現(xiàn)調用接口加載頁面初始數(shù)據(jù)

    使用Vue實現(xiàn)調用接口加載頁面初始數(shù)據(jù)

    今天小編就為大家分享一篇使用Vue實現(xiàn)調用接口加載頁面初始數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • 基于Vue3封裝實現(xiàn)圖片查看器

    基于Vue3封裝實現(xiàn)圖片查看器

    這篇文章主要為大家詳細介紹了如何基于Vue3封裝實現(xiàn)一個圖片查看器,可以點擊圖片放大和關閉放大的圖片,感興趣的小伙伴可以了解一下
    2025-02-02
  • vue+Vue Router多級側導航切換路由(頁面)的實現(xiàn)代碼

    vue+Vue Router多級側導航切換路由(頁面)的實現(xiàn)代碼

    這篇文章主要介紹了vue+Vue Router多級側導航切換路由(頁面)的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • vue2老項目中node-sass更換dart-sass的操作方法

    vue2老項目中node-sass更換dart-sass的操作方法

    這篇文章主要介紹了vue2老項目中node-sass更換dart-sass的操作方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2024-07-07

最新評論