当前位置: 首页 > wzjs >正文

模板网站与定制网站的价格2021年年度关键词排名

模板网站与定制网站的价格,2021年年度关键词排名,wordpress 编程,网站制作的软件有哪些欢迎观看《Vue Router 实战(第4版)》视频课程 路由的匹配语法 大多数应用都会使用 /about 这样的静态路由和 /users/:userId 这样的动态路由,就像我们刚才在动态路由匹配中看到的那样,但是 Vue Router 可以提供更多的方式&#…

欢迎观看《Vue Router 实战(第4版)》视频课程

    1. 路由的匹配语法

大多数应用都会使用 /about 这样的静态路由和 /users/:userId 这样的动态路由,就像我们刚才在动态路由匹配中看到的那样,但是 Vue Router 可以提供更多的方式!

TIP

为了简单起见,所有的路由都省略了 component 属性,只关注 path 值。

      1. 在参数中自定义正则

当定义像 :userId 这样的参数时,我们内部使用以下的正则 ([^/]+) (至少一个不是斜杠 / 的字符)来从 URL 中提取参数。这很好用,除非你需要根据参数的内容来区分两个路由。想象一下,两个路由 /:orderId 和 /:productName,两者会匹配完全相同的 URL,所以我们需要一种方法来区分它们。最简单的方法就是在路径中添加一个静态部分来区分它们:

const routes = [

  // 匹配 /o/3549

  { path: '/o/:orderId' },

  // 匹配 /p/books

  { path: '/p/:productName' },

]

但在某些情况下,我们并不想添加静态的 /o /p 部分。由于,orderId 总是一个数字,而 productName 可以是任何东西,所以我们可以在括号中为参数指定一个自定义的正则:

const routes = [

  // /:orderId -> 仅匹配数字

  { path: '/:orderId(\\d+)' },

  // /:productName -> 匹配其他任何内容

  { path: '/:productName' },

]

现在,转到 /25 将匹配 /:orderId,其他情况将会匹配 /:productName。routes 数组的顺序并不重要!

TIP

确保转义反斜杠( \ ),就像我们对 \d (变成\\d)所做的那样,在 JavaScript 中实际传递字符串中的反斜杠字符。

      1. 可重复的参数

如果你需要匹配具有多个部分的路由,如 /first/second/third,你应该用 *(0 个或多个)和 +(1 个或多个)将参数标记为可重复:

const routes = [

  // /:chapters ->  匹配 /one, /one/two, /one/two/three, 等

  { path: '/:chapters+' },

  // /:chapters -> 匹配 /, /one, /one/two, /one/two/three, 等

  { path: '/:chapters*' },

]

这将为你提供一个参数数组,而不是一个字符串,并且在使用命名路由时也需要你传递一个数组:

// 给定 { path: '/:chapters*', name: 'chapters' },

router.resolve({ name: 'chapters', params: { chapters: [] } }).href

// 产生 /

router.resolve({ name: 'chapters', params: { chapters: ['a', 'b'] } }).href

// 产生 /a/b

// 给定 { path: '/:chapters+', name: 'chapters' },

router.resolve({ name: 'chapters', params: { chapters: [] } }).href

// 抛出错误,因为 `chapters` 为空

这些也可以通过在右括号后添加它们与自定义正则结合使用:

const routes = [

  // 仅匹配数字

  // 匹配 /1, /1/2, 等

  { path: '/:chapters(\\d+)+' },

  // 匹配 /, /1, /1/2, 等

  { path: '/:chapters(\\d+)*' },

]

      1. Sensitive 与 strict 路由配置

默认情况下,所有路由是不区分大小写的,并且能匹配带有或不带有尾部斜线的路由。例如,路由 /users 将匹配 /users、/users/、甚至 /Users/。这种行为可以通过 strict 和 sensitive 选项来修改,它们既可以应用在整个全局路由上,又可以应用于当前路由上:

const router = createRouter({

  history: createWebHistory(),

  routes: [

    // 将匹配 /users/posva 而非:

    // - /users/posva/ 当 strict: true

    // - /Users/posva 当 sensitive: true

    { path: '/users/:id', sensitive: true },

    // 将匹配 /users, /Users, 以及 /users/42 而非 /users/ 或 /users/42/

    { path: '/users/:id?' },

  ],

  strict: true, // applies to all routes

})

      1. 可选参数

你也可以通过使用 ? 修饰符(0 个或 1 个)将一个参数标记为可选:

const routes = [

  // 匹配 /users 和 /users/posva

  { path: '/users/:userId?' },

  // 匹配 /users 和 /users/42

  { path: '/users/:userId(\\d+)?' },

]

请注意,* 在技术上也标志着一个参数是可选的,但 ? 参数不能重复。

      1. 调试

如果你需要探究你的路由是如何转化为正则的,以了解为什么一个路由没有被匹配,或者,报告一个 bug,你可以使用路径排名工具。它支持通过 URL 分享你的路由。

http://www.dtcms.com/wzjs/78689.html

相关文章:

  • 做营销型网站价格南宁网站制作
  • wordpress存档:合肥seo推广排名
  • 网站做扫一扫百度搜索引擎下载免费
  • 网站建设服务费如何做会计分录网络营销与直播电商专业学什么
  • 建设银行ETC的网站是哪个如何联系百度人工客服电话
  • 鞍山做网站团队百度网站建设
  • 怎样做娱乐网站网站设计流程
  • 怎么做网站海报中国十大电商公司排名
  • 企业建站费用情况网络市场营销
  • 项目网站建设应入哪个科目长沙做引流推广的公司
  • 网站抓取QQ获取系统软文投稿平台有哪些
  • 新乡市做网站烟台百度推广公司
  • 中企动力做网站的优势朋友圈产品推广文案
  • 怎么做特色网站网络营销顾问
  • 台州集团网站建设北京网络营销
  • 替网站做任务怎么做的新闻摘抄大全
  • 做网站需要哪些程序如何自己建个网站
  • 建国外网站需要多少钱自己有域名怎么建网站
  • 哪个网站课件做的比较好app开发公司推荐
  • wordpress控制文章显示合肥seo管理
  • 淘客联盟如何做网站推广成都关键词优化报价
  • 做网站模版与定制的区别有必要买优化大师会员吗
  • 做柜子的常去的网站百度账号登录不了
  • 破解网站后台账号密码百度网站怎么做
  • 专做外贸的网站有哪些资料株洲网页设计
  • 政府公文写作网站百度账号登录
  • 自助建微网站各大网站推广平台
  • 免费网站建设模板下载宁波正规优化seo软件
  • 门户网站是如何做引流的西安网站优化公司
  • 广州网站建设维护河南制作网站