js關(guān)于近似匹配路徑

最近用到antdmenu導(dǎo)航菜單組件,官網(wǎng)中默認(rèn)選中菜單功能defaultSelectedKeys只能默認(rèn)選中已有的菜單,對(duì)于不在菜單中的內(nèi)嵌子頁(yè)面并不能默認(rèn)選中父菜單,菜單沒(méi)有選中狀態(tài)。所以我要想辦法得到內(nèi)嵌子頁(yè)面的父菜單,放到defaultSelectedKeys中。
比如當(dāng)前的菜單的url是: http://xxx.com/system/user/detail/789404
我要在菜單數(shù)組中匹配到最相近的父菜單:

 menus = [
{url: '/', name: '首頁(yè)'},
{url: '/system', name: '系統(tǒng)'},
{url: '/system/user', name: '用戶(hù)', children: [{url: '/system/user/detail', name: '用戶(hù)詳情'}]},
{url: '/system/role', name: '角色', children: [{url: '/system/role/detail', name: '角色詳情'}]},
{url: '404', name: '404'},//會(huì)有一些亂七八糟的路徑
...
]

也就是: /system/user/detail/
用了react-router-dommatchPath方法,只能精確的匹配路徑,看來(lái)要自己寫(xiě)了。。。
根據(jù)群友的提示,想到了用js的match大法

image.png

由此可看出match能篩選出包含有字符串的路徑,好的成功了第一步!
但是也發(fā)現(xiàn)了match會(huì)把404這種路徑都篩選出來(lái)了,換成startsWith會(huì)更好!

image.png

第二步就是將這些篩選出來(lái)的路徑進(jìn)行進(jìn)一步取值,根據(jù)規(guī)律可看出路徑url.length最長(zhǎng)的就是最匹配的

resultMenu= menus.reduce((acc, cur) => (acc.url.length > cur.url.length) ? acc : cur)

完整代碼:

/**
pathname:  '/system/user/detail/789404'
menus:  菜單數(shù)組
*/
getMenuPath = (pathname, menus) => {
    let result = [] //模糊匹配到的路徑
    let resultMenu = [] //最終匹配到的路徑
    // 得到所有的模糊匹配路徑
    const foo = (_menus) => {
      _menus.forEach(_menu => {
        const { url, children, ...rest } = _menu
        // 用startsWith匹配到開(kāi)頭路徑
        if (url && pathname.startsWith(url) && !Array.isArray(children)) {
          result = result.concat([{ url, ...rest }])
        } else if (Array.isArray(children)) {
          //如果還有children 深層遞歸
          foo(children)
        }
      })
    }
    foo(copyJson(menus))
    if (result.length > 0) {
      // 得到最近似精確的匹配路徑 url越長(zhǎng)說(shuō)明越精確
      resultMenu= result.reduce((acc, cur) => (acc.url.length > cur.url.length) ? acc : cur)
    }
    return resultMenu
}

const menus = [
{url: '/', name: '首頁(yè)'},
{url: '/system', name: '系統(tǒng)'},
{url: '/system/user', name: '用戶(hù)', children: [{url: '/system/user/detail', name: '用戶(hù)詳情'}]},
{url: '/system/role', name: '角色', children: [{url: '/system/role/detail', name: '角色詳情'}]},
{url: '404', name: '404'}//會(huì)有一些亂七八糟的路徑
]
const pathname = location.pathname
//調(diào)用
getMenuPath(pathname, menus)

最終獲取到的路徑是:{url: '/system/user/detail', name: '用戶(hù)詳情'},完美解決問(wèn)題。如有更好的解決方法,跪求留言指教

END-----------------------------------------------
tips: 簡(jiǎn)書(shū)上交流可能會(huì)看不到消息,如有問(wèn)題,歡迎進(jìn)群交流50063010

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 已經(jīng)同步到gitbook,想閱讀的請(qǐng)轉(zhuǎn)到gitbook: Django 1.10 中文文檔 URL dispatc...
    leyu閱讀 14,441評(píng)論 0 16
  • ¥開(kāi)啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開(kāi)一個(gè)線程,因...
    小菜c閱讀 7,355評(píng)論 0 17
  • 目錄: 0×00、什么是Acunetix Web Vulnarability Scanner ( What is ...
    SkTj閱讀 6,777評(píng)論 0 3
  • 我希望 從這一秒開(kāi)始 早睡早起 認(rèn)真學(xué)習(xí) 按時(shí)吃飯 我希望 從這一秒之后的一秒開(kāi)始 會(huì)有風(fēng) 會(huì)有陽(yáng)光 會(huì)...
    三木SAMMU閱讀 227評(píng)論 3 1
  • 英語(yǔ)語(yǔ)言能力分為聽(tīng)、說(shuō)和讀寫(xiě),這是一項(xiàng)全面的技能,四項(xiàng)技能哪一門(mén)都不能落下。 這四項(xiàng)技能又分為兩類(lèi),閱讀和聽(tīng)力屬于...
    竹說(shuō)閱讀 532評(píng)論 0 0

友情鏈接更多精彩內(nèi)容