通过 ID Vuejs 从对象数组传递数据
Pass Data from Array of objects by ID Vuejs
我有 2 个 .vue 页面(列表、详细信息)
现在在列表中我列出了这样的对象数组我从 API
得到它们
[{...},{...},{...}]
我使用 v-for
在列表中显示它
我在每个列表中都有详细信息按钮
当我点击“详细信息”时,我会将对象的 ID 路由到“详细信息”页面
我可以在控制台中打印 ID,我可以在 .vue
中打印它
使用:$this.route.params.ID;
但我无法获取 ID = $this.route.params.ID;
的其他数据
我已经尝试了 3 天...
<div
class="col-lg-12 col-md-12 col-xs-12 pa-4 ma-4"
v-for="(cmpd, index) in Compounds"
:key="cmpd.id"
>
<v-card
class="mx-auto"
:flat="flat"
:loading="loading"
:outlined="outlined"
:elevation="elevation"
:raised="raised"
>
<v-img
v-if="media"
class="white--text"
height="250px"
>
<v-card-title class="align-end fill-height">
{{cmpd.name}} ({{cmpd.city}})
<router-link :to="{ name: 'CompoundDetails', params: { CompoundID:
cmpd.id }}">
<v-btn text>Details</v-btn>
</router-link>
</v-card-title>
</v-img>
<v-card-title v-else>{{cmpd.name}}</v-card-title>
</div>
我看到您正在传递带有 CompoundID: cmpd.id
的 ID。但是你想要所有的对象和信息,对吧?那么为什么不传递整个对象呢? params: { Compound: cmpd }
。然后你就拥有了整个对象。
如果您正在使用 Vuex,您也可以将它放在商店中以便从任何地方访问。
我有 2 个 .vue 页面(列表、详细信息) 现在在列表中我列出了这样的对象数组我从 API
得到它们
[{...},{...},{...}]
我使用 v-for
在列表中显示它我在每个列表中都有详细信息按钮
当我点击“详细信息”时,我会将对象的 ID 路由到“详细信息”页面
我可以在控制台中打印 ID,我可以在 .vue
中打印它
使用:$this.route.params.ID;
但我无法获取 ID = $this.route.params.ID;
我已经尝试了 3 天...
<div
class="col-lg-12 col-md-12 col-xs-12 pa-4 ma-4"
v-for="(cmpd, index) in Compounds"
:key="cmpd.id"
>
<v-card
class="mx-auto"
:flat="flat"
:loading="loading"
:outlined="outlined"
:elevation="elevation"
:raised="raised"
>
<v-img
v-if="media"
class="white--text"
height="250px"
>
<v-card-title class="align-end fill-height">
{{cmpd.name}} ({{cmpd.city}})
<router-link :to="{ name: 'CompoundDetails', params: { CompoundID:
cmpd.id }}">
<v-btn text>Details</v-btn>
</router-link>
</v-card-title>
</v-img>
<v-card-title v-else>{{cmpd.name}}</v-card-title>
</div>
我看到您正在传递带有 CompoundID: cmpd.id
的 ID。但是你想要所有的对象和信息,对吧?那么为什么不传递整个对象呢? params: { Compound: cmpd }
。然后你就拥有了整个对象。
如果您正在使用 Vuex,您也可以将它放在商店中以便从任何地方访问。