国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【Vue】監(jiān)控路由與路由參數(shù), 刷新當(dāng)前頁面數(shù)據(jù)的幾種方法

這篇具有很好參考價值的文章主要介紹了【Vue】監(jiān)控路由與路由參數(shù), 刷新當(dāng)前頁面數(shù)據(jù)的幾種方法。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

目錄

一、Vue監(jiān)控路由

1、Vue中watch監(jiān)控路由

2、Vue中watch監(jiān)控路由的某一個參數(shù)

3、Vue中watch同時監(jiān)控多個路由

二、刷新當(dāng)前頁面數(shù)據(jù)

1、location.reload

2、$router.go(0)

3、this.$router.resolve()與this.$router.resolve()

a、this.$router.resolve()

b、this.$router.push()

三、示例場景

四、往期相關(guān)優(yōu)質(zhì)推薦


vue監(jiān)聽路由變化刷新頁面,vue.js,javascript,前端

Vue官網(wǎng) Element官網(wǎng)

vue監(jiān)聽路由變化刷新頁面,vue.js,javascript,前端

vue監(jiān)聽路由變化刷新頁面,vue.js,javascript,前端

一、Vue監(jiān)控路由

1、Vue中watch監(jiān)控路由

????????如果你想要監(jiān)控整個路由對象的變化,包括路由路徑、參數(shù)、查詢參數(shù)等的變化,可以使用`$route`對象進行監(jiān)控。以下是一個使用`watch`監(jiān)控整個路由對象的示例:

<template>
  <div>
    <!-- 顯示監(jiān)控的路由信息 -->
    <div>{{ monitoredRoute }}</div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      monitoredRoute: null, // 用于存儲監(jiān)控的路由信息
    };
  },
  watch: {
    '$route'(newRoute) {
      this.monitoredRoute = newRoute; // 將新的路由信息保存到組件的monitoredRoute屬性中
      // 執(zhí)行其他操作或調(diào)用其他方法
    },
    //或
    $route(newRoute) {
      this.monitoredRoute = newRoute; // 將新的路由信息保存到組件的monitoredRoute屬性中
      // 執(zhí)行其他操作或調(diào)用其他方法
    },
  },
};
</script>

在這個示例中,我們在組件的`data`選項中定義了一個`monitoredRoute`屬性,用于存儲監(jiān)控的路由信息。在`watch`選項中,使用`'$route'`來指定要監(jiān)控的路由對象。當(dāng)路由發(fā)生變化時,`watch`函數(shù)會被觸發(fā),將新的路由信息保存到組件的`monitoredRoute`屬性中。

你可以根據(jù)需要在`watch`函數(shù)中執(zhí)行其他操作或調(diào)用其他方法,例如根據(jù)路由信息更新組件的狀態(tài)、重新加載數(shù)據(jù)等。

請注意,上述示例中的`monitoredRoute`是一個示例屬性名,你可以根據(jù)需要將其替換為你自己定義的屬性名。

2、Vue中watch監(jiān)控路由的某一個參數(shù)

在Vue中,可以使用`watch`選項來監(jiān)控路由的某一個參數(shù)的變化。以下是一個使用`watch`監(jiān)控路由參數(shù)的示例:

<template>
  <div>
    <!-- 顯示監(jiān)控的參數(shù)值 -->
    <div>{{ monitoredParam }}</div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      monitoredParam: null, // 用于存儲監(jiān)控的參數(shù)值
    };
  },
  watch: {
    '$route.params.monitoredParam'(newValue) {
      this.monitoredParam = newValue; // 將新的參數(shù)值保存到組件的monitoredParam屬性中
      // 執(zhí)行其他操作或調(diào)用其他方法
    },
  },
};
</script>

在這個示例中,我們在組件的`data`選項中定義了一個`monitoredParam`屬性,用于存儲監(jiān)控的參數(shù)值。在`watch`選項中,使用`'$route.params.monitoredParam'`來指定要監(jiān)控的路由參數(shù)。當(dāng)監(jiān)控的參數(shù)發(fā)生變化時,`watch`函數(shù)會被觸發(fā),將新的參數(shù)值保存到組件的`monitoredParam`屬性中。

你可以根據(jù)需要在`watch`函數(shù)中執(zhí)行其他操作或調(diào)用其他方法,例如根據(jù)參數(shù)值更新組件的狀態(tài)、重新加載數(shù)據(jù)等。

請注意,上述示例中的`monitoredParam`是一個示例參數(shù)名,你需要將其替換為你要監(jiān)控的實際參數(shù)名。另外,如果你還需要監(jiān)控其他路由參數(shù),可以在`watch`選項中添加相應(yīng)的監(jiān)控函數(shù)。

3、Vue中watch同時監(jiān)控多個路由

<template>
  <div>
    <!-- 顯示監(jiān)控的路由信息 -->
    <div>{{ monitoredRoute }}</div>
    <!-- 顯示監(jiān)控的參數(shù)值 -->
    <div>{{ monitoredParam }}</div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      monitoredRoute: null, // 用于存儲監(jiān)控的路由信息
      monitoredParam: null, // 用于存儲監(jiān)控的參數(shù)值
    };
  },
  watch: {
    '$route'(newRoute) {
      this.monitoredRoute = newRoute; // 將新的路由信息保存到組件的monitoredRoute屬性中
      // 執(zhí)行其他操作或調(diào)用其他方法
    },
    '$route.params.monitoredParam'(newValue) {
      this.monitoredParam = newValue; // 將新的參數(shù)值保存到組件的monitoredParam屬性中
      // 執(zhí)行其他操作或調(diào)用其他方法
    },
  },
};
</script>

二、刷新當(dāng)前頁面數(shù)據(jù)

1、location.reload

在Vue.js中,可以使用`location.reload()`方法重新加載當(dāng)前頁面。這個方法會導(dǎo)致瀏覽器重新發(fā)送請求并重新加載頁面。

要在Vue組件中使用`location.reload()`,可以在需要重新加載頁面的地方調(diào)用該方法。例如,在一個按鈕的點擊事件處理程序中:

methods: {
  reloadPage() {
    location.reload();
  }
}

然后,在模板中使用這個方法:

<button @click="reloadPage">重新加載頁面</button>

當(dāng)用戶點擊按鈕時,頁面將會重新加載。

需要注意的是,`location.reload()`方法會導(dǎo)致頁面完全重新加載,包括重新執(zhí)行Vue實例的生命周期鉤子函數(shù)。這可能會導(dǎo)致數(shù)據(jù)丟失,因為重新加載后,Vue實例將會被重置。

如果你只是想重新加載某個組件或重新獲取數(shù)據(jù),而不是整個頁面,你可以考慮使用Vue的其他方法,如重新發(fā)起異步請求或重新設(shè)置組件的數(shù)據(jù)。

2、$router.go(0)

????????在Vue.js中,可以使用`$router.go()`方法進行路由導(dǎo)航。該方法用于在路由之間進行前進或后退操作。`$router.go()`方法接受一個整數(shù)作為參數(shù),表示前進或后退的步數(shù)。正數(shù)表示前進,負數(shù)表示后退。

下面是`$router.go()`方法的使用方法示例:

序號 代碼 釋義
1 this.$router.go(-1);?? // 后退+刷新;
2 this.$router.go(0);??? // 刷新;
3 this.$router.go(1);??? // 前進一步
4 this.$router.go(2);??? // 前進兩步
5 this.$router.go(n);??? // 前進n個頁面

你可以在Vue組件的方法中使用`$router.go()`方法來觸發(fā)路由導(dǎo)航。例如,在一個按鈕的點擊事件處理程序中:

methods: {
  goForward() {
    this.$router.go(1);
  },
  goBack() {
    this.$router.go(-1);
  }
}

然后,在模板中使用這些方法:

<button @click="goForward">前進</button>
<button @click="goBack">后退</button>

當(dāng)用戶點擊"前進"按鈕時,將向前導(dǎo)航一步。當(dāng)用戶點擊"后退"按鈕時,將后退一步。

需要注意的是,`$router.go()`方法只能在使用Vue Router進行路由管理的應(yīng)用程序中使用。如果你的應(yīng)用程序沒有配置Vue Router,或者當(dāng)前路由沒有前進或后退的歷史記錄,`$router.go()`方法可能不會產(chǎn)生任何效果。

3、this.$router.resolve()與this.$router.resolve()

????????`this.$router.resolve()`和`this.$router.push()`是Vue Router中的兩個不同的方法,用于處理路由相關(guān)的操作,但它們有不同的作用和使用方式。

a、this.$router.resolve()

  • 作用:用于解析路由的相關(guān)信息,而不進行實際的導(dǎo)航操作。
  • 使用方式:接受一個路由路徑作為參數(shù),并返回一個Promise對象,該Promise對象包含解析后的路由信息。
  • ?示例:
const resolvedRoute = this.$router.resolve('/example-route');
resolvedRoute.then(route => {
   // 處理解析后的路由信息
});

b、this.$router.push()

  • 作用:用于進行路由導(dǎo)航,將用戶導(dǎo)航到指定的路由。
  • 使用方式:接受一個路由路徑或一個描述路由的對象作為參數(shù),進行實際的導(dǎo)航操作。
  • 示例:
// 導(dǎo)航到指定路由路徑
this.$router.push('/example-route');
// 導(dǎo)航到帶參數(shù)的路由
this.$router.push({ path: '/example-route', query: { id: 1 } });

使用`this.$router.resolve()`方法時,你可以獲取解析后的路由信息,但它并不會觸發(fā)實際的路由導(dǎo)航。而使用`this.$router.push()`方法時,會將用戶導(dǎo)航到指定的路由路徑或描述的路由對象。

因此,如果你只需要獲取解析后的路由信息而不進行實際的導(dǎo)航操作,可以使用`this.$router.resolve()`方法。如果需要進行實際的路由導(dǎo)航,應(yīng)該使用`this.$router.push()`方法。

三、示例場景

???????比如一個頁面需要有可能跳轉(zhuǎn)到相同頁面,? 也可能跳轉(zhuǎn)到不同頁面, 為了體驗更好,? 可以綜合情況判斷使用那種刷新方式。

//頁面類型變化直接
'$route.query.type'(newValue) {
	this.$router.push("/xx/yy_detail?type=0&id=" + row.id);
}

//相同頁面相同數(shù)據(jù)但需要重新渲染(條件結(jié)合具體情況)
'$route.query.xx'(newValue) {
  this.$router.go(0);
}

//相同頁面不同數(shù)據(jù)
'$route'(newValue) {
  this.init();
},

methods: {
    init(){
      this.detail();
      this.$refs["ppData"].flush(this.$route.query.id);
      this.$refs["fileData"].flush(this.$route.query.id);
      this.$refs["child3"].flush(this.$route.query.id);
      this.$refs["child4"].flush(this.$route.query.id);
      this.$refs["child5"].flush(this.$route.query.id);
      this.$refs["child6"].flush(this.$route.query.id);
    },
},

四、往期相關(guān)優(yōu)質(zhì)推薦

VSCode 最全實用插件(VIP典藏版)
Vue超詳細整理(VIP典藏版)
Vue中created,mounted,updated詳解
一文快速上手Echarts(持續(xù)更新)
Vue中el-table數(shù)據(jù)項擴展各種類型總結(jié)(持續(xù)更新)

vue監(jiān)聽路由變化刷新頁面,vue.js,javascript,前端

有用請點贊,養(yǎng)成良好習(xí)慣!

疑問、交流、鼓勵請留言!文章來源地址http://www.zghlxwxcb.cn/news/detail-712937.html

到了這里,關(guān)于【Vue】監(jiān)控路由與路由參數(shù), 刷新當(dāng)前頁面數(shù)據(jù)的幾種方法的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • VUE實現(xiàn)當(dāng)前頁面刷新的七種方法

    ????????使用 location.reload() 方法可以簡單地實現(xiàn)當(dāng)前頁面的刷新,這個方法會重新加載當(dāng)前頁面,類似于用戶點擊瀏覽器的刷新按鈕。 ????????在 Vue 中,可以將該方法綁定到 Vue 實例上,比如在 Vue 的 methods 中添加如下的方法: ????????然后在模板中調(diào)用該方法即

    2024年02月16日
    瀏覽(19)
  • uniapp,轉(zhuǎn)微信小程序,獲取當(dāng)前頁面的 路由、路由參數(shù)

    uniapp,轉(zhuǎn)微信小程序,獲取當(dāng)前頁面的 路由、路由參數(shù)

    uniapp 獲取當(dāng)前路由信息跟 vue 不同,它沒有 route 對象。 uniapp 轉(zhuǎn)成小程序后是這樣的 當(dāng)前頁面展示的路由信息就是上一條中獲取到的 pages 的最后一條路由,即 它的內(nèi)容是: 當(dāng)前路由的參數(shù) 在 currentRoute.options 中 比如 index?type=diarydiaryid=123 的 options 就是 而 當(dāng)前頁面的完整路

    2024年02月14日
    瀏覽(99)
  • vue獲取當(dāng)前路由的幾種方式

    第一種 第二種 通過getCurrentInstance 獲取當(dāng)前的組件實例,從而通過其獲取router,然后胡德當(dāng)前路由地址 第三種 第四種 第五種

    2024年02月13日
    瀏覽(24)
  • vue路由跳轉(zhuǎn)后,刷新指定頁面。

    vue路由跳轉(zhuǎn)后,刷新指定頁面。

    ????????做項目遇到一個坑:A頁面帶參跳轉(zhuǎn)到B頁面,第二次跳轉(zhuǎn)時的參數(shù)與第一次時的參數(shù)不同,但是后臺查詢時還是使用的第一次的參數(shù)。需要手動刷新之后,才會使用第二次參數(shù)。 ? ? ? ? 鑒于時間原因直接使用刷新頁面監(jiān)聽路由的方法。在準(zhǔn)備跳轉(zhuǎn)的A頁面添加路

    2024年02月12日
    瀏覽(34)
  • vue 動態(tài)路由刷新失效及404頁面處理

    在開發(fā)后臺管理項目,我們會使用vue動態(tài)路由做權(quán)限管理,但是使用vue動態(tài)路由時會遇到一些坑,這里總結(jié)一下,并提供解決思路 問題:刷新頁面時會把addRouter添加的動態(tài)路由刷新掉,因此瀏覽器找不到之前添加的路由,便會進入白屏頁面或者404頁面 處理方式:判斷是否刷

    2024年02月12日
    瀏覽(28)
  • VUE路由跳轉(zhuǎn)并刷新頁面(框架層實現(xiàn))

    前言 ? ? ? ? 網(wǎng)上找了很多辦法,都需要開發(fā)者在頁面內(nèi)單獨實現(xiàn),或者是刷新整個瀏覽器,感覺并不是特別舒服。因此,我考慮可以在框架層去實現(xiàn)路由跳轉(zhuǎn)刷新。 ? ? ? ? 思路如下: ? ? ? ? ? ? ? ? 1、重定向至臨時界面(用戶無感知) ? ? ? ? ? ? ? ? 2、打開臨時

    2024年02月11日
    瀏覽(26)
  • Vue路由模式(history模式 刷新頁面空白解決方案)

    Vue路由模式(history模式 刷新頁面空白解決方案)

    vue路由的三種模式 Hash模式 、 History模式 、 abstract 模式 Vue3: Hash 模式是用 createWebHashHistory() 創(chuàng)建的: Vue2 它在內(nèi)部傳遞的實際 URL 之前使用了一個哈希字符(#)。由于這部分 URL 從未被發(fā)送到服務(wù)器,所以它不需要在服務(wù)器層面上進行任何特殊處理。不過,它在 SEO 中確實有

    2024年02月12日
    瀏覽(31)
  • vue3 動態(tài)添加路由刷新后頁面丟失(白屏)問題

    vue3 動態(tài)添加路由刷新后頁面丟失(白屏)問題

    動態(tài)添加路由操作一般是用vuex或者Pinia封裝,在登錄頁面調(diào)用 如果出現(xiàn)刷新頁面丟失有兩種可能: 1:vuex或者Pinia沒有做持久化處理 2:動態(tài)添加路由需要在main.ts里面也調(diào)用一次 不需要路由守衛(wèi)即可實現(xiàn) 注意:必須要在頁面掛載前還有路由配置完成前調(diào)用添加,不然還是丟

    2024年02月16日
    瀏覽(28)
  • 關(guān)于vue路由跳轉(zhuǎn)后的頁面不會刷新的解決辦法

    做uni項目的時候遇到的情況:1,父組件頁面刷新了之后 需要觸底加載的子組件能觸底加載,否則不能加載。2,子組件不能觸底加載,只需要刷新之后就能觸底加載。以上的刷新不包括下拉刷新。3. 可能因為包了一層tab頁導(dǎo)致跳轉(zhuǎn)進頁面沒有請求數(shù)據(jù)的問題。 我的解決辦法是

    2024年02月11日
    瀏覽(28)
  • vue通過router地址傳參跳轉(zhuǎn)同一路由頁面,頁面不刷新的解決辦法

    vue、 vue-router@4 記錄一下最近遇到的vue路由頁面間的跳轉(zhuǎn)的問題,其中就涉及到了不同路由的跳轉(zhuǎn)(/a/b1 = /a/b2)、相同路由不同參數(shù)間的跳轉(zhuǎn)(/a/b?c=1 = /a/b?c=2)、相同頁面錨點跳轉(zhuǎn)(/a/b#id1 =/a/b#id2) 原因:渲染的是同一組件 解決:可以在不刷新的頁面通過監(jiān)聽route,重新加載

    2024年02月04日
    瀏覽(22)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包