vue循环复用同一组件
时间: 2023-07-28 12:40:15 浏览: 125
解决vue一个页面中复用同一个echarts组件的问题
在 Vue 中,你可以使用 `v-for` 指令来循环渲染同一个组件,实现循环复用。首先,你需要定义一个父组件,然后在父组件中使用 `v-for` 指令来循环渲染子组件,并将数据通过 props 传递给子组件。
下面是一个简单的例子,假设你需要渲染多个文章列表,每个列表包含多篇文章。你可以创建两个组件:`ArticleList` 和 `ArticleItem`,其中 `ArticleList` 组件循环渲染 `ArticleItem` 组件,并将数据通过 props 传递给 `ArticleItem` 组件。
```
<template>
<div>
<article-item v-for="(article, index) in articles" :key="index" :title="article.title" :content="article.content" />
</div>
</template>
<script>
import ArticleItem from './ArticleItem.vue';
export default {
components: {
ArticleItem,
},
data() {
return {
articles: [
{ title: 'Article 1', content: 'This is article 1.' },
{ title: 'Article 2', content: 'This is article 2.' },
{ title: 'Article 3', content: 'This is article 3.' },
],
};
},
};
</script>
```
在 `ArticleList` 组件中,使用 `v-for` 指令循环遍历 `articles` 数组,将数组中的每个元素渲染成 `ArticleItem` 组件,并通过 props 传递 `title` 和 `content` 数据。
```
<template>
<div>
<h3>{{ title }}</h3>
<p>{{ content }}</p>
</div>
</template>
<script>
export default {
props: {
title: String,
content: String,
},
};
</script>
```
在 `ArticleItem` 组件中,定义了 `title` 和 `content` 两个 props,用于接收父组件传递过来的数据。这样,就可以实现循环复用 `ArticleItem` 组件,渲染多篇文章。
阅读全文