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

Vue監(jiān)控路由與路由參數, 刷新當前頁面數據的方法匯總

 更新時間:2023年10月19日 10:01:41   作者:慕白Lee  
這篇文章主要介紹了Vue監(jiān)控路由與路由參數, 刷新當前頁面數據的幾種方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧

Vue官網Element官網

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

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

        如果你想要監(jiān)控整個路由對象的變化,包括路由路徑、參數、查詢參數等的變化,可以使用`$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í)行其他操作或調用其他方法
    },
    //或
    $route(newRoute) {
      this.monitoredRoute = newRoute; // 將新的路由信息保存到組件的monitoredRoute屬性中
      // 執(zhí)行其他操作或調用其他方法
    },
  },
};
</script>

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

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

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

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

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

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

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

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

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

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

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

二、刷新當前頁面數據

1、location.reload

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

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

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

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

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

當用戶點擊按鈕時,頁面將會重新加載。

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

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

2、$router.go(0)

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

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

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

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

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

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

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

當用戶點擊"前進"按鈕時,將向前導航一步。當用戶點擊"后退"按鈕時,將后退一步。

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

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

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

a、this.$router.resolve()

  • 作用:用于解析路由的相關信息,而不進行實際的導航操作。
  • 使用方式:接受一個路由路徑作為參數,并返回一個Promise對象,該Promise對象包含解析后的路由信息。
  •  示例:

示例:

const resolvedRoute = this.$router.resolve('/example-route');
resolvedRoute.then(route => {
   // 處理解析后的路由信息
});

b、this.$router.push()

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

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

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

三、示例場景

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

//頁面類型變化直接
'$route.query.type'(newValue) {
	this.$router.push("/xx/yy_detail?type=0&id=" + row.id);
}
//相同頁面相同數據但需要重新渲染(條件結合具體情況)
'$route.query.xx'(newValue) {
  this.$router.go(0);
}
//相同頁面不同數據
'$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);
    },
},

到此這篇關于Vue監(jiān)控路由與路由參數, 刷新當前頁面數據的幾種方法的文章就介紹到這了,更多相關Vue監(jiān)控路由與路由參數, 刷新當前頁面數據內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 使用mockjs如何生成隨機數據

    使用mockjs如何生成隨機數據

    Mockjs是一個用于生成隨機數據和攔截Ajax請求的庫,可以與Vue和Axios結合使用,提高前端開發(fā)效率,通過在項目中引入Mock.js文件,可以模擬后端API,攔截Ajax請求并返回自定義響應,這種方法適用于在后端尚未開發(fā)完成時的前端開發(fā)測試
    2024-10-10
  • vue router+vuex實現首頁登錄驗證判斷邏輯

    vue router+vuex實現首頁登錄驗證判斷邏輯

    這篇文章主要介紹了vue router+vuex實現首頁登錄判斷邏輯,用于判斷是否登錄首頁,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • vue之el-upload使用FormData多文件同時上傳問題

    vue之el-upload使用FormData多文件同時上傳問題

    這篇文章主要介紹了vue之el-upload使用FormData多文件同時上傳問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue自定義指令合集(超實用!)

    vue自定義指令合集(超實用!)

    Vue自定義指令是Vue中一種非常有用的擴展能力,它允許你在標準的模板語法中使用自定義行為,而不需要編寫新的組件或者混入,這篇文章主要給大家介紹了關于vue自定義指令的相關資料,需要的朋友可以參考下
    2024-03-03
  • vue封裝axios與api接口管理的完整步驟

    vue封裝axios與api接口管理的完整步驟

    在實際的項目中,和后臺的數據交互是少不了的,我通常使用的是 axios 庫,所以下面這篇文章主要給大家介紹了關于vue封裝axios與api接口管理的相關資料,需要的朋友可以參考下
    2022-01-01
  • Vue3 reactive響應式賦值頁面不渲染的解決

    Vue3 reactive響應式賦值頁面不渲染的解決

    這篇文章主要介紹了Vue3 reactive響應式賦值頁面不渲染的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue 封裝自定義組件之tabal列表編輯單元格組件實例代碼

    vue 封裝自定義組件之tabal列表編輯單元格組件實例代碼

    這篇文章主要介紹了vue 封裝自定義組件tabal列表編輯單元格組件實例代碼,需要的朋友可以參考下
    2017-09-09
  • vue實現跨頁面定位錨點區(qū)域方式

    vue實現跨頁面定位錨點區(qū)域方式

    這篇文章主要介紹了vue實現跨頁面定位錨點區(qū)域方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 解決vue組件props傳值對象獲取不到的問題

    解決vue組件props傳值對象獲取不到的問題

    這篇文章主要介紹了vue組件props傳值,對象獲取不到的問題,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • 在 Vue.js中優(yōu)雅地使用全局事件的方法

    在 Vue.js中優(yōu)雅地使用全局事件的方法

    這篇文章主要介紹了在 Vue.js中優(yōu)雅地使用全局事件的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-02-02

最新評論