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

vue實現前端保持篩選條件到url并進行同步參數設計

 更新時間:2022年08月11日 09:43:55   作者:daisY  
這篇文章主要為大家介紹了vue實現前端保持篩選條件到url并進行同步參數設計思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

前言

在有列表頁的系統(tǒng)中,常常為了提高用戶體驗,需要保持列表頁的篩選條件、分頁情況。需要做到刷新頁面,從詳情頁返回列表頁保留之前的篩選情況。你可能會說 vue 用 keep-alive 緩存列表頁不就行了?為什么不好呢?

因為正確的做法是將篩選條件保存在 url 上,這樣可以復制給別人直接使用,并且你可以看到幾乎所有網站都是使用這種方法。接下來會帶大家了解有關 url 參數的基礎知識和設計思路。并且封裝成了一個 hook vue-use-sync-url,歡迎在你的項目中直接使用。

基礎知識

假設 url 上的參數為 ?a=1&a=2&b=true,來看看獲取參數的方法

const searchParams = new URLSearchParams(window.location.search);
// ["1", "2"]
searchParams.getAll("a");
// "1"
searchParams.get(a);
// ["true"]
searchParams.getAll(b);
// "true"
searchParams.get(b);

添加

searchParams.append("a", "1");
searchParams.append("a", "2");
// ?a=1&a=2
searchParams.set("b", "3");
searchParams.set("b", "4");
// ?b=4

從上面的結果可以得知,無論什么值最后都會被解析成 string 類型, 如果存在兩個名字相同的 key,則會被解析為 string[]。 所以從 url 參數獲取到的類型只會為 string | string[]。

最后使用 history.pushState 來修改瀏覽器地址欄的 url 參數。與 history.replaceState 不同的是,一個是添加一條新記錄,一個是替換。在這里我們當然是選擇添加新記錄了。

設計思路

首先肯定要知道哪些值需要同步到 url 參數上,所以我們定義了一個 configs 參數,來配置需要同步的值。類型為數組,這樣可以讓用戶自定義順序,每項需要傳入一個 key 值。

hook 內部返回一個 syncToUrl 方法,傳入包含配置的所有 key 的值。用戶可以在自己需要的時候同步 url。

const { syncToUrl } = useSyncUrl({
  configs: [{ key: "title" }, { key: "status" }]
})
// 同步
syncToUrl(values)

假設 title 與輸入框綁定,且沒有值,傳入 syncToUrl 的是 "",這就沒有必要同步到 url 上了。所以我們添加一個配置 omitEmptyString,如果值為空字符串,則忽略。

[{ key: "title", omitEmptyString: true }]

同理,可以增加 omitNullomitUndefined。這三個默認都設為 true。

接下來,我們先明白兩個概念。在頁面第一次加載、執(zhí)行瀏覽器前進回退操作時,需要將 url 參數的值轉換到當前頁面的組件中,在這里我們稱其為 decode。

在頁面中篩選結束點擊提交或切換頁碼時,需要將這些值轉換成參數并設置到 url 的參數上,在這里我們稱其為 encode。

decode

了解后,我們就可以知道上面例子中 key: "status",可以想成是一個 Select 組件,值為 boolean 類型。從基礎知識可以得知,從 url 取下來的值為 string 類型。 需要使用 decode 轉換成 boolean 類型。

const values = reactive({ title: "", status: false });
const booleanValues = {
  true: true,
  false: false,
}
const { syncToUrl } = useSyncUrl({
  configs: [
    {
      // title 的值是字符串類型,所以不需要 decode
      key: "title",
    },
    { 
      key: "status", 
      // 參數是從 url 上 key 為 status 的值
      decode: (value) => booleanValues[value] 
    }
  ],
  onDecode: (params) => {
    Object.keys(params).forEach(key => {
        values[key] = params[key]
    });
    // 設置完成后,在這里請求數據
  }
})

decode 中,我們將值 return 出去,在 onDecode 中將每個配置項返回的值統(tǒng)一收集起來,設置完成后,請求列表數據。像 title 這種值本身是字符串的就不用寫 decode。假設 url 上的參數為 ?title=11&status=true,這里的 params 的值就為

{
  title: "11",
  status: true
}

decode 也可以返回一個對象,如果是對象也會被收集到 onDecode 中。如果不想被收集,可以返回空對象 {}。所以如果你想在 decode 中進行賦值也可以,但要返回 {}。

decode: (value) => {
  return {
    a: "1",
    b: "2"
  }
}
// 不會被收集
decode: (value) => {
  return {};
}

encode

const values = reactive({ rangeDate: ["2022-10-1", "2022-10-2"] });
useSyncUrl({
  configs: [
   {
     key: "rangeDate",
     encode: (value) => {
       return {
         starDate: value[0],
         endDate: value[1]
       }
     }
   }
  ]
})

encode 可以將值轉換成你想要的格式同步到 url 上。這個例子中如果不寫 encode,通過了解上面的基礎知識,則會被轉換成兩個 rangeDate 的鍵值對。這里自定義轉換成了 starDate 和 endDate。所以還要配合 decode 使用。

decode: (value) => ...

但是這個 value 返回的是 url 上 key 為 "rangeDate" 的值,我們要怎么 decode starDate 和 endDate 呢?所以增加一個配置項 decodeKeys 來實現。。

{
 key: "rangeDate",
 decodeKeys: ["starDate", "endDate"],
 decode: value => {
   return {
     rangeDate: [value.starDate, value.endDate]
   }
 }
}

通過上面基礎知識可以得知,url 的值只能為 string | string[],所以 encode 返回的值也只能是 EncodeResult | Record<string, EncodeResult>。內部將 numberboolean 轉換成了 string

type EncodeResult = string | number | boolean | (string | number | boolean)[];

這時候就有問題了,我想將一個比較復雜類型的值同步到 url 上怎么辦?這時候就要用到 encodeURIComponentdecodeURIComponent 了,如果你不認識,可以上 MDN 學習。這里判定數據一定為正確的,實際使用中在 decode 這步中 JSON.parse 可能會報錯,你需要自行處理一下,因為 url 可能會被人為修改。

const values = reactive({
  obj: { a: { b: { c: true } } },
});
const { syncToUrl } = useSyncUrl({
  configs: [
    {
      key: "obj",
      encode: (value) => encodeURIComponent(JSON.stringify(value)),
      decode: (value) => JSON.parse(decodeURIComponent(value)),
    },
  ],
});

詳情頁返回列表頁

假如你的詳情頁有一個按鈕點擊返回列表頁,要怎么保留上次的篩選條件呢?因為 vue-router 的 push 操作,不能直接傳 url 參數的字符串,只能傳對象,所以返回一個參數對象。

localStorage.setItem("listSearch", window.location.search);
// 在詳情頁
router.push(`/list${localStorage.getItem("listSearch")}`)
或
const { searchParams } = useSyncUrl(...)
localStorage.setItem("listSearch", JSON.stringify(searchParams))
// 在詳情頁
router.push({ path: "/list", query: JSON.parse(localStorage.getItem("listSearch")) })

結語

源碼放在 github 了,readme 中還有測試地址,可以來試一試。

以上就是vue實現前端保持篩選條件到url并進行同步參數設計的詳細內容,更多關于vue篩選條件url同步參數設計的資料請關注腳本之家其它相關文章!

相關文章

  • vue結合vue-electron創(chuàng)建應用程序小結

    vue結合vue-electron創(chuàng)建應用程序小結

    這篇文章主要介紹了vue結合vue-electron創(chuàng)建應用程序,本文給大家介紹了安裝electron有兩種方式,兩種方式創(chuàng)建的項目結構大不相同,需要的朋友可以參考下
    2024-03-03
  • Vue生命周期中的八個鉤子函數相機

    Vue生命周期中的八個鉤子函數相機

    這篇文章主要為大家介紹了Vue生命周期中的八個鉤子函數,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • vuex的module模塊用法示例

    vuex的module模塊用法示例

    這篇文章主要介紹了vuex的module模塊用法示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • Vue開發(fā)之封裝分頁組件與使用示例

    Vue開發(fā)之封裝分頁組件與使用示例

    這篇文章主要介紹了Vue開發(fā)之封裝分頁組件與使用,結合實例形式分析了vue.js封裝分頁組件操作以及使用組件進行分頁的相關實現技巧,需要的朋友可以參考下
    2019-04-04
  • Vue.js中的computed工作原理

    Vue.js中的computed工作原理

    這篇文章,我們通過實現一個簡單版的和Vue中computed具有相同功能的函數來了解computed是如何工作的。對Vue.js中的computed工作原理感興趣的朋友跟隨腳本之家小編一起學習吧
    2018-03-03
  • vue.js模版插值的原理與實現方法簡析

    vue.js模版插值的原理與實現方法簡析

    這篇文章主要介紹了vue.js模版插值的原理與實現方法,結合實例形式簡單分析了vue.js模板插值的基本功能、原理、實現方法與注意事項,需要的朋友可以參考下
    2023-04-04
  • antdv vue upload自定義上傳結合表單提交方式

    antdv vue upload自定義上傳結合表單提交方式

    這篇文章主要介紹了antdv vue upload自定義上傳結合表單提交方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 微信小程序用戶盒子、宮格列表的實現

    微信小程序用戶盒子、宮格列表的實現

    這篇文章主要介紹了微信小程序用戶盒子、宮格列表,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • vue實現短信驗證碼登錄功能(流程詳解)

    vue實現短信驗證碼登錄功能(流程詳解)

    無論是移動端還是pc端登錄或者注冊界面都會見到手機驗證碼登錄這個功能,輸入手機號,得到驗證碼,這篇文章主要介紹了基于vue實現短信驗證碼登錄功能,需要的朋友可以參考下
    2019-12-12
  • vue中異步函數async和await的用法說明

    vue中異步函數async和await的用法說明

    這篇文章主要介紹了vue中異步函數async和await的用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評論