vue利用计算属性做(展开收起)(整理)

简介: vue利用计算属性做(展开收起)(整理)
<template>
  <div class="wrap">
    <div class="box">
      <div v-for="item in showItem">{{item}}</div>
      <div style="color: red;" @click="showAll = !showAll">{{btnText}}</div>
    </div>
  </div>
</template>
<script>
  export default {
    data() {
      return {
        foodList: [
          "测试1", "测试2", "测试3", "测试4", "测试5", "测试6", "测试7" //进行显示的数据
        ],
        showAll: false //标记数据是否需要完全显示的属性
      }
    },
    computed: {
      showItem() {
        if (this.showAll == false) { //当数据不需要完全显示的时候
          var showItem = []; //定义一个空数组
          if (this.foodList.length > 4) { //这里我们先显示前四个--核心-开始显示几条
            for (var i = 0; i < 4; i++) {
              showItem.push(this.foodList[i])
            }
          } else {
            showItem = this.foodList
          }
          return showItem; //返回当前数组
        } else {
          return this.foodList;
        }
      },
      btnText() {
        if (this.showAll == false) { //对文字进行处理(枚举)
          return "展开全部"
        } else {
          return "收起"
        }
      }
    }
  }
</script>
<style lang="less" scoped>
  .box{
    display: flex;
    div{
      margin-left: 20px;
    }
  }
</style>

相关文章
|
2天前
|
JavaScript
vue消息订阅与发布
vue消息订阅与发布
|
1天前
|
JavaScript
vue尚品汇商城项目-day07【vue插件-50.(了解)表单校验插件】
vue尚品汇商城项目-day07【vue插件-50.(了解)表单校验插件】
10 4
|
1天前
|
JavaScript
vue尚品汇商城项目-day07【51.路由懒加载】
vue尚品汇商城项目-day07【51.路由懒加载】
11 4
|
2天前
|
JavaScript 前端开发
Vue学习笔记8:解决Vue学习笔记7中用v-for指令渲染列表遇到两个问题
Vue学习笔记8:解决Vue学习笔记7中用v-for指令渲染列表遇到两个问题
|
1天前
|
JavaScript
vue尚品汇商城项目-day07【vue插件-54.(了解)生成二维码插件】
vue尚品汇商城项目-day07【vue插件-54.(了解)生成二维码插件】
7 2
|
4天前
|
JavaScript
vue组件中的插槽
本文介绍了Vue中组件的插槽使用,包括单个插槽和多个具名插槽的定义及在父组件中的使用方法,展示了如何通过插槽将父组件的内容插入到子组件的指定位置。
|
3天前
|
JavaScript 前端开发 IDE
Vue学习笔记5:用Vue的事件监听 实现数据更新的实时视图显示
Vue学习笔记5:用Vue的事件监听 实现数据更新的实时视图显示
|
3天前
|
JavaScript 前端开发 API
Vue学习笔记4:用reactive() 实现数据更新的实时视图显示
Vue学习笔记4:用reactive() 实现数据更新的实时视图显示
|
2天前
|
JavaScript 前端开发 API
Vue学习笔记7:使用v-for指令渲染列表
Vue学习笔记7:使用v-for指令渲染列表
|
3天前
|
JavaScript
vue 函数化组件
vue 函数化组件