gpt4 book ai didi

javascript - 如何在 VueJS 中将值从一个子组件传递到另一个子组件?

转载 作者:行者123 更新时间:2023-12-03 17:48:33 26 4
gpt4 key购买 nike

完整源代码:https://github.com/tenzan/menu-ui-tw

演示:https://flamboyant-euclid-6fcb57.netlify.com/

目标:

ItemsListItemImageMenu.vue 的子组件。我需要将 image_urlItemsList 传递给 ItemImage,以便在左侧的项目按时自动更改后更改右侧的图像间隔。

  • 左侧:组件 ItemsList.vue
  • 右侧:组件 ItemImage.vue

enter image description here

组件 Menu.vue 有 2 个子组件:

<template>
<div>
<!-- Two columns -->
<div class="flex mb-4">
<div class="w-1/2 bg-gray-400">
<ItemsList />
</div>
<div class="w-1/2 bg-gray-500">
<ItemImage></ItemImage>
</div>
</div>
</div>
</template>

<script>
import ItemsList from "./ItemsList";
import ItemImage from "./ItemImage";

export default {
components: {
ItemsList,
ItemImage
}
};
</script>

ItemsList.vue:

<template>
<div>
<div v-for="item in menuItems" :key="item.name">
<ul
class="flex justify-between bg-gray-200"
:class="item.highlight ? 'highlight' : ''"
>
<p class="px-4 py-2 m-2">
{{ item.name }}
</p>
<p class="px-4 py-2 m-2">
{{ item.price }}
</p>
</ul>
</div>
</div>
</template>

<script>
export default {
data() {
return {
menuItems: [
{
name: "Apple",
price: 20,
image_url: "../assets/images/apple.jpg"
},
{
name: "Orange",
price: 21,
image_url: "../assets/images/orange.jpg"
},
{
name: "Banana",
price: 22,
image_url: "../assets/images/banana.jpg"
},
{
name: "Grape",
price: 23,
image_url: "../assets/images/grape.jpg"
}
]
};
},
created() {
var self = this;
self.menuItems.map((x, i) => {
self.$set(self.menuItems[i], "highlight", false);
});
var init = 0;
setInterval(function() {
if (init === self.menuItems.length) {
init = 0;
}
self.menuItems[init].highlight = true;
if (init === 0) {
self.menuItems[self.menuItems.length - 1].highlight = false;
} else {
self.menuItems[init - 1].highlight = false;
}
init++;
}, 2000);
}
};
</script>

<style scoped>
.highlight {
background-color: gray;
}
</style>

ItemImage.vue - 几乎是空的

<template>
<div><p>Hello from ItemImage component</p></div>
</template>

<script>
export default {
props: ["image_url"]
};
</script>

ItemsList 遍历每个项目并突出显示它。我将需要组件 ItemImage 来显示该事件/突出显示 项目的图像。图片的 URL 是 item.image_url

最佳答案

在 ItemsList 组件中使用 image_url 发出事件,在 Menu 组件中将 image_url 作为 Prop 传递给 ItemImage 组件。我在下面的 codesandbox 中做了这个检查。

https://codesandbox.io/s/wild-moon-mbto4

关于javascript - 如何在 VueJS 中将值从一个子组件传递到另一个子组件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59855921/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com