vue中父组件动态改变子组件的过滤器filter

本文通过一个示例展示了如何在Vue中从父组件动态控制子组件的过滤器,特别是在一个包含el-select的场景下。子组件接收来自父组件的属性,包括是否启用过滤器、过滤函数,根据这些来决定el-select的禁用状态。父组件通过传递方法myfilter来实现具体过滤逻辑,当val.a等于3时,select选项变为可用,否则不可用。此案例对于理解Vue组件间通信和自定义过滤器的使用具有参考价值。
摘要由CSDN通过智能技术生成

最近有个朋友问我怎么在父组件动态改变子组件的过滤器filter,想了一下写了一个demo案例

子组件内容如下:

<template>
  <div>
    <div v-for="(item,index) in tests" :id="index">
      <el-select
        v-model="selectData"
        multiple
        filterable
        allow-create
        default-first-option
        :disabled="item | disabledFilter(disabled,enableFilter,fatherMethod)"
        placeholder="请选择文章标签">
        <el-option
          v-for="item1 in options"
          :key="item1.value"
          :label="item1.label"
          :value="item1.value">
        </el-option>
      </el-select>
    </div>
  </div>
</template>

<script>
  export default {
    name: "testSelect",
    props: {
      // 未开启过滤器时使用
      disabled: {
        type: Boolean,
        default: () => false
      },
      // 开启过滤器
      enableFilter: {
        type: Boolean,
        default: () => false
      },
      // 开启过滤器使用
      fatherMethod: {
        type: Function,
        default: () => null
      }
    },
    data() {
      return {
        selectData:'',
        options: [{
          value: 'HTML',
          label: 'HTML'
        }, {
          value: 'CSS',
          label: 'CSS'
        }, {
          value: 'JavaScript',
          label: 'JavaScript'
        }],
        tests: [
          {
            a: 1,
            b: 1
          },
          {
            a: 2,
            b: 2
          },
          {
            a: 3,
            b: 3
          },
          {
            a: 4,
            b: 4
          },
        ],
      }
    },
    filters: {
      disabledFilter(val, disabled, enableFilter, fatherMethod) {
        if (enableFilter) {
          if (fatherMethod) {
            return fatherMethod(val);
          }
          return false;
        } else {
          return disabled
        }
      }
    },
  }
</script>

<style scoped>

</style>

父组件调用

<testSelect :enableFilter="true" :father-method="myfilter"></testSelect>

  methods: {
    myfilter(val){
      if(val.a === 3){
        return true
      }else{
        return false
      }
    },
 }

效果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

haohao_ding

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值