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

导读:本篇文章讲解 vue中父组件动态改变子组件的过滤器filter,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

最近有个朋友问我怎么在父组件动态改变子组件的过滤器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
      }
    },
 }

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/5321.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!