表单组件二次封装(vue-elementui、搜索条件)

搜索条件组件

(SearchForm\index.vue放在目录的components下):

<!-- 搜索表单 -->
<template>
  <div class="ces-search">
    <el-form class="input" :size="size" inline :label-width="labelWidth">
      <el-form-item v-for="item in searchForm" :key="item.prop" :label="item.label">
        <!-- 输入框 -->
        <el-input v-if="item.type==='Input'" v-model="searchData[item.prop]" size="mini"  clearable @clear="clearParams('searchData[item.prop]')"/>
        <!-- 下拉框 -->
        <el-select v-if="item.type==='Select'" v-model="searchData[item.prop]" size="mini" filterable clearable @change="item.change(searchData[item.prop])">
          <el-option v-for="(op, index) in item.options" :key="index" :label="op.label" :value="op.value" />
        </el-select>
        <!-- 单选 -->
        <el-radio-group v-if="item.type==='Radio'" v-model="searchData[item.prop]">
          <el-radio v-for="ra in item.radios" :key="ra.value" :label="ra.value">{{ ra.label }}</el-radio>
        </el-radio-group>
        <!-- 单选按钮 -->
        <el-radio-group v-if="item.type==='RadioButton'" v-model="searchData[item.prop]" @change="item.change && item.change(searchData[item.prop])">
          <el-radio-button v-for= "ra in item.radios" :key="ra.value" :label="ra.value">{{ ra.label }}</el-radio-button>
        </el-radio-group>
        <!-- 复选框 -->
        <el-checkbox-group v-if="item.type==='Checkbox'" v-model="searchData[item.prop]">
          <el-checkbox v-for="ch in item.checkboxs" :key="ch.value" :label="ch.value">{{ ch.label }}</el-checkbox>
        </el-checkbox-group>
        <!--  年份选择器      -->
        <el-date-picker
          v-if="item.type==='year'"
          v-model="searchData[item.prop]"
          value-format="yyyy-MM-dd HH:mm:ss"
          type="year"
          placeholder="选择年"
          @change="item.change(searchData[item.prop])">
        </el-date-picker>
        <!-- 日期 -->
        <el-date-picker v-if="item.type==='Date'" v-model="searchData[item.prop]" />
        <!-- 时间 -->
        <el-time-select v-if="item.type==='Time'" v-model="searchData[item.prop]" type="" />
        <!-- 日期时间 -->
        <el-date-picker v-if="item.type==='DateTime'" v-model="searchData[item.prop]" type="datetime" :disabled="item.disable && item.disable(searchData[item.prop])" />
        <!-- 日期和时间范围选择器  -->
        <el-date-picker
          v-if="item.type==='daterange'"
          v-model="searchData[item.prop]"
          value-format="yyyy-MM-dd HH:mm:ss"
          type="daterange"
          start-placeholder="开始日期"
          end-placeholder="结束日期"
        />
        <!--  年月      -->
        <el-date-picker
          v-if="item.type==='monthrange'"
          v-model="searchData[item.prop]"
          type="monthrange"
          range-separator="-"
          start-placeholder="开始月份"
          end-placeholder="结束月份">
        </el-date-picker>
        <!-- 日期和时间范围(最新)       -->
        <el-date-picker
          v-if="item.type==='datetimerange'"
          v-model="searchData[item.prop]"
          value-format="yyyy-MM-dd HH:mm:ss"
          type="datetimerange"
          range-separator=""
          start-placeholder="开始日期"
          end-placeholder="结束日期"
          @change="item.change(searchData[item.prop])"
        >
        </el-date-picker>
        <!-- 滑块 -->
        <!-- <el-slider v-if="item.type==='Slider'" v-model="searchData[item.prop]"></el-slider> -->
        <!-- 开关 -->
        <el-switch v-if="item.type==='Switch'" v-model="searchData[item.prop]" />
      </el-form-item>
    </el-form>
    <el-form v-if="isHandle" inline class="button">
      <el-form-item v-for="item in searchHandle" :key="item.label">
        <el-button :type="item.type" :size="item.size || size" @click="item.handle()">{{ item.label }}</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
  props: {
    isHandle: {
      type: Boolean,
      default: true
    },
    labelWidth: {
      type: String,
      default: '100px'
    },
    size: {
      type: String,
      default: 'mini'
    },
    searchForm: {
      type: Array,
      // eslint-disable-next-line vue/require-valid-default-prop
      default: []
    },
    searchHandle: {
      type: Array,
      default: () => []
    },
    searchData: {
      type: Object,
      // eslint-disable-next-line vue/require-valid-default-prop
      default: {}
    }
  },
  data() {
    return {
    }
  },
  methods: {
    // 置空参数
    clearParams(val) {
      // eslint-disable-next-line no-return-assign
      // Object.keys(this.searchData).forEach(key => this.searchData[key] = '')
    }
  }
}

</script>
<style scoped>
  .input{
    float: left;
  }
  .button{
    float: left;
  }
  .el-form-item__content {
    line-height: 28px;
  }
</style>

父组件中引入

html部分:

 <search-form class="searchMain" size="mini" label-width="80px" :search-data="searchData" :search-form="searchForm" :search-handle="searchHandle" />
          

js部分:

import SearchForm from '@/components/SearchForm'
export default {
  components: {  SearchForm },
  data() {
    return {
	    searchData: { // 查询参数
	        pageNum: 1, pageSize: 5, userId: undefined, buildingId: undefined, communityId: undefined,
	        merchantId: undefined, roomNo: undefined, unitId: undefined,
	        data: { mobilePhone: undefined, residentName: undefined }
	    },
	    searchForm: [
	        { type: 'Input', label: '室', prop: 'roomNo', width: '100px', placeholder: '请输入室...' },
	        { type: 'Input', label: '姓名', prop: 'residentName', width: '100px', placeholder: '请输入姓名...' },
	        { type: 'Input', label: '手机号', prop: 'mobilePhone', width: '100px', placeholder: '请输入手机号码...' }
	    ],
	    searchHandle: [
	        { label: '查询', type: 'primary', handle: this.getList },
	        { label: '重置', type: 'primary', handle: this.resetForm }
	    ],
    }
  },
  methods:{
  // 获取小区列表、表格信息
    getList() {
      this.loadingTable = true
      this.searchData.userId = this.$store.getters.id
      this.searchData.data.mobilePhone = this.searchData.mobilePhone
      this.searchData.data.residentName = this.searchData.residentName

      listResident(this.searchData).then((response) => {
        const row = response.data.rows || []
        this.list = row.map(function(val) {
          val.identity = val.residentIdentity
          if (val.residentIdentity !== undefined) {
            val.residentIdentity = val.residentIdentity + 0 === 1 ? '住户' : '租户'
          }
          return val
        })
        this.total = response.data.total
        this.loadingTable = false
        this.loading = false
      })
    },
    // 表格重置
    resetForm() {
      Object.assign(this.$data.searchData, this.$options.data().searchData)
    }
  }
}

css部分

.searchMain {
    height: 100px;
 }

(提示:searchData里面不需要的自行删掉,方法和api也是自己写合适的)

详解:

1、子组件的
在这里插入图片描述
与父组件的在这里插入图片描述
对应
2、子组件里的在这里插入图片描述
与父组件里的
在这里插入图片描述
对应

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue-ElementUI中实现搜索的方法有多种。根据引用中的内容,你可以使用自定义的computed属性来实现搜索功能。具体步骤如下: 1. 首先,你需要在你的Vue组件中添加一个搜索框用于输入关键字。 2. 然后,你可以在computed属性中创建一个新的属性,例如"tables",用于存储过滤后的数据。 3. 在"tables"属性的定义中,你可以使用filter()方法对"tableData"进行过滤,只保留那些包含搜索关键字的数据。 4. 在filter()方法中,你可以使用Object.keys()方法获取对象数组的所有枚举属性,然后使用some()方法进行匹配判断,只要有一个属性匹配成功,就返回整个对象。 5. 在匹配时,你可以将对象属性的值转换成小写,并使用indexOf()方法来判断是否包含搜索关键字。 6. 最后,根据搜索框中是否有值,来返回过滤后的数据或者全部数据。 下面是一个示例代码供你参考: ```javascript computed: { tables() { let search = this.search.toLowerCase(); if (search) { return this.tableData.filter(data => { return Object.keys(data).some(key => { if (data[key !== null) { return data[key].toString().toLowerCase().indexOf(search) > -1; } }); }); } else { return this.tableData; } } } ``` 通过以上步骤,你就可以在Vue-ElementUI格中实现搜索功能了。注意,其中的"tableData"是你需要展示在格中的数据,"search"是搜索框中输入的关键字。你可以根据自己的实际情况进行调整。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [vue+element-ui的组件实现简搜索框功能](https://blog.csdn.net/kurodasense/article/details/122782200)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [vue-elementui-tree-table.rar](https://download.csdn.net/download/qq_32442967/12015371)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值