当前位置:首页 > VUE

vue实现列表组件

2026-02-17 21:13:44VUE

Vue 列表组件实现方法

基础列表渲染

使用 v-for 指令可以轻松实现列表渲染。通过遍历数组或对象,动态生成列表项。

<template>
  <ul>
    <li v-for="(item, index) in items" :key="index">
      {{ item.name }}
    </li>
  </ul>
</template>

<script>
export default {
  data() {
    return {
      items: [
        { name: 'Item 1' },
        { name: 'Item 2' },
        { name: 'Item 3' }
      ]
    }
  }
}
</script>

动态绑定属性

列表项可以绑定动态属性和事件,实现交互功能。

<template>
  <ul>
    <li 
      v-for="(item, index) in items" 
      :key="item.id"
      :class="{ active: item.isActive }"
      @click="toggleActive(index)"
    >
      {{ item.name }}
    </li>
  </ul>
</template>

<script>
export default {
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1', isActive: false },
        { id: 2, name: 'Item 2', isActive: false },
        { id: 3, name: 'Item 3', isActive: false }
      ]
    }
  },
  methods: {
    toggleActive(index) {
      this.items[index].isActive = !this.items[index].isActive
    }
  }
}
</script>

列表过滤与排序

通过计算属性可以实现列表的过滤和排序功能。

<template>
  <div>
    <input v-model="searchQuery" placeholder="Search...">
    <ul>
      <li v-for="item in filteredItems" :key="item.id">
        {{ item.name }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      searchQuery: '',
      items: [
        { id: 1, name: 'Apple' },
        { id: 2, name: 'Banana' },
        { id: 3, name: 'Orange' }
      ]
    }
  },
  computed: {
    filteredItems() {
      return this.items.filter(item => 
        item.name.toLowerCase().includes(this.searchQuery.toLowerCase())
      )
    }
  }
}
</script>

可编辑列表

实现一个可以编辑的列表组件,允许用户修改列表项内容。

<template>
  <ul>
    <li v-for="(item, index) in items" :key="item.id">
      <input v-if="item.isEditing" v-model="item.name" @blur="item.isEditing = false">
      <span v-else @click="item.isEditing = true">{{ item.name }}</span>
      <button @click="removeItem(index)">Remove</button>
    </li>
    <button @click="addItem">Add Item</button>
  </ul>
</template>

<script>
export default {
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1', isEditing: false },
        { id: 2, name: 'Item 2', isEditing: false }
      ]
    }
  },
  methods: {
    addItem() {
      this.items.push({
        id: Date.now(),
        name: 'New Item',
        isEditing: true
      })
    },
    removeItem(index) {
      this.items.splice(index, 1)
    }
  }
}
</script>

性能优化

对于大型列表,可以使用 v-forkey 属性和 Vue 的虚拟滚动技术优化性能。

<template>
  <div style="height: 300px; overflow-y: auto">
    <div v-for="item in largeList" :key="item.id" style="height: 50px">
      {{ item.name }}
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      largeList: Array.from({ length: 1000 }, (_, i) => ({
        id: i,
        name: `Item ${i + 1}`
      }))
    }
  }
}
</script>

组件化列表

将列表项封装为单独组件,提高代码复用性和可维护性。

<template>
  <ul>
    <list-item 
      v-for="item in items" 
      :key="item.id"
      :item="item"
      @remove="removeItem"
    />
  </ul>
</template>

<script>
import ListItem from './ListItem.vue'

export default {
  components: { ListItem },
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' }
      ]
    }
  },
  methods: {
    removeItem(id) {
      this.items = this.items.filter(item => item.id !== id)
    }
  }
}
</script>

以上方法涵盖了 Vue 列表组件的主要实现方式,可以根据实际需求选择适合的方案或组合使用。

vue实现列表组件

标签: 组件列表
分享给朋友:

相关文章

vue实现组件

vue实现组件

Vue 组件实现基础 Vue 组件是可复用的 Vue 实例,用于封装 UI 和逻辑。通过 .vue 文件或直接注册组件实现。 单文件组件 (SFC) 示例 <template&g…

实现vue组件

实现vue组件

创建 Vue 组件 Vue 组件可以通过单文件组件(.vue 文件)或直接在 JavaScript 中定义。以下是两种常见实现方式。 单文件组件方式 单文件组件包含模板、脚本和样式三部分,适合复杂…

js实现列表

js实现列表

使用 JavaScript 实现列表 JavaScript 提供了多种方式来实现列表功能,包括数组操作、DOM 元素动态生成等。以下是几种常见的实现方法: 使用数组存储列表数据 数组是 JavaSc…

vue实现组件跟随

vue实现组件跟随

Vue 实现组件跟随效果 实现组件跟随效果通常需要监听鼠标或触摸事件,动态更新组件位置。以下是几种常见实现方式: 使用鼠标事件绑定 <template> <div class=…

jquery 列表

jquery 列表

jQuery 列表操作 jQuery 提供了多种方法来操作 HTML 列表(如 <ul> 或 <ol>)。以下是一些常见的操作方式: 动态添加列表项 使用 append()…

uniapp 滑动组件

uniapp 滑动组件

uniapp 滑动组件实现方法 使用swiper组件 uniapp内置的swiper组件可以实现滑动效果,适用于轮播图或页面切换场景。 示例代码: <swiper :indicator-…