【问题标题】:Passing a page id from menu从菜单传递页面 id
【发布时间】:2021-09-07 17:21:11
【问题描述】:

我对 vue/nuxt 非常陌生,在为无头 cms 实现前端时遇到了这个问题。

我有两条这样的路线

页面

-StandardPage
    ->_standardPage.vue
-InfoPage
    ->_InfoPage.vue

我的 _standardPage.vue 和 _infoPage.vue 有这个代码(现在相同,但会改变)基本上他们需要一个 guid Id 来从 Api 获取页面信息。页面信息包含不同的块,然后是动态生成的组件:

<template>
 <div>
  <Menu />
   <div v-for="block in site.blocks" :key="block.id">
    <component :is="block.blockName" :blockData="block"/>
   </div>
 </div>
</template>

<script>
export default{
  data(){
  return {
    site: Object
  }},
  methods: {
    this.site = result from async method, calling api to get page info by guid id (how do i get a hold of this guid)
  }
}

现在的问题是,在我的菜单组件中,我正在获取菜单显示名称和相应的 pageId(菜单项可以随心所欲地添加/删除,所以我无法事先知道这些 ID),当我单击我希望将页面 ID 传递到我的标准或信息页面的菜单项,以便他们可以获取相应的数据但没有成功。

我曾尝试将 $emit 从子级发送到父级,但跨路由执行此操作没有成功。如果我使用路径和查询执行 $router.push,我会在 url 中得到一个讨厌的 guid,这看起来不太友好。

将 guid 从菜单组件传递到路由页面的最佳方式是什么?

【问题讨论】:

  • 所以,这确实适用于一些查询参数,对吧? router.vuejs.org/guide/essentials/…
  • 如果我使用带名称而不是路径的路由器推送,我可以发送我在菜单中单击的第一个 guid,但它保持静态并在此之后发送相同的 guid,无论我单击菜单项。也许我以某种方式设置错了?
  • 您通常应该更喜欢使用name 而不是path,当然,在这种情况下命名您的组件。

标签: vue.js vuejs2 nuxt.js


【解决方案1】:

如果你的父母中有一个按钮看起来像

<button @click="$router.push({ name: 'details-page', params: { guid: '123' } })">
  test
</button>

这在名为/pages/details-page.vue的孩子中

<script>
export default {
  name: 'DetailsPage',
  async fetch() {
    console.log('route', this.$route.params.guid)
    await axios...
  },
}
</script>

您将能够根据您的guid 在子项中加载一些数据,并且不会出现丑陋的路径。

【讨论】:

  • 嗨,谢谢,快到了!但是,如果我现在有 2 个或更多“DetailsPage”并在它们之间导航,它们指向相同的路线并发送相同的 ID。例如,我有页面 a、b、c(所有详细信息页面),我单击页面 a 并且 guid 1 被记录,我现在单击页面 b 并且 guid 1 仍然被记录
  • 1.您的页面应该有一个唯一的名称。 2. 如果你不能有一个独特的文件来处理你的所有案例,你确实可以将它们分成几页。 3. 如果你想发送到不同的页面,你需要发送一些动态的.push({ name: dynamicName }) 并且可能还根据你点击的元素更新guid 的值。 4. 如果没有这部分的任何代码,我无能为力。也许尝试使用您的 devtools 或 console.log 查看您实际通过路由器传递的内容,但这应该可以正常工作,如我的示例所示。
  • 谢谢,也许我对问题的解释很糟糕,但是你给了我一个很好的方向,最后我决定使用 vuex 来更新/保留当前页面 guid 以便于访问。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-04-08
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2022-09-26
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多