123 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
| <!-- 搜索表单 -->
 | |
| <template>
 | |
|   <div class="base-search-form">
 | |
|     <el-form :size="size" :inline="true" :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]" :placeholder="item.placeholder" size="mini" :style="{width:item.width}" :readonly="item.readonly" />
 | |
|         <!-- 下拉框 -->
 | |
|         <el-select
 | |
|           v-if="item.type==='Select'"
 | |
|           v-model="searchData[item.prop]"
 | |
|           :placeholder="item.placeholder"
 | |
|           size="mini"
 | |
|           :style="{width:item.width}"
 | |
| 
 | |
|           @change="item.change && item.change(that,searchData[item.prop])"
 | |
|         >
 | |
|           <el-option
 | |
|             v-for="op in item.options"
 | |
|             :key="op[item.props['label']]"
 | |
|             :label="op[item.props['label']]"
 | |
|             :value="op[item.props['value']]"
 | |
|           />
 | |
|         </el-select>
 | |
|         <el-select
 | |
|           v-if="item.type==='Select2'"
 | |
|           v-model="searchData[item.prop]"
 | |
|           :placeholder="item.placeholder"
 | |
|           size="mini"
 | |
|           :style="{width:item.width}"
 | |
| 
 | |
|           @change="item.change && item.change(that,searchData[item.prop])"
 | |
|         >
 | |
|           <el-option
 | |
|             v-for="(key,value) of item.options"
 | |
|             :key="key"
 | |
|             :label="key"
 | |
|             :value="value"
 | |
|           />
 | |
|         </el-select>
 | |
|         <!-- 单选 -->
 | |
|         <el-radio-group v-if="item.type==='Radio'" v-model="searchData[item.prop]" :style="{width:item.width}">
 | |
|           <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]" :style="{width:item.width}" @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]" :style="{width:item.width}">
 | |
|           <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==='Date'" v-model="searchData[item.prop]" :placeholder="item.placeholder" :style="{width:item.width}" value-format="yyyy-MM-dd" format="yyyy-MM-dd" :picker-options="item.pickerOption" />
 | |
|         <!-- 时间 -->
 | |
|         <el-time-select v-if="item.type==='Time'" v-model="searchData[item.prop]" :placeholder="item.placeholder" type="" :style="{width:item.width}" />
 | |
|         <!-- 日期时间 -->
 | |
|         <el-date-picker v-if="item.type==='DateTime'" v-model="searchData[item.prop]" :placeholder="item.placeholder" type="datetime" :disabled="item.disable && item.disable(searchData[item.prop])" :style="{width:item.width}" />
 | |
|         <!-- 滑块 -->
 | |
|         <!-- <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]" :style="{width:item.width}" />
 | |
|         <!-- 具名slot -->
 | |
|         <slot v-if="item.type==='Custom'" :name="item.slot" />
 | |
|       </el-form-item>
 | |
|       <el-form-item v-for="item in searchHandle" :key="item.label">
 | |
|         <slot v-if="item.slot" :name="item.slot" />
 | |
|         <el-button v-else :type="item.type" :size="item.size || size" :icon="item.icon || ''" @click="handleClick(item.emitKey)">{{ item.label }}</el-button>
 | |
|       </el-form-item>
 | |
|     </el-form>
 | |
|   </div>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| export default {
 | |
|   props: {
 | |
|     that: {
 | |
|       type: Object,
 | |
|       default: this
 | |
|     },
 | |
|     isHandle: {
 | |
|       type: Boolean,
 | |
|       default: true
 | |
|     },
 | |
|     labelWidth: {
 | |
|       type: String,
 | |
|       default: ''
 | |
|     },
 | |
|     size: {
 | |
|       type: String,
 | |
|       default: 'mini'
 | |
|     },
 | |
|     searchForm: {
 | |
|       type: Array,
 | |
|       default: () => []
 | |
|     },
 | |
|     searchHandle: {
 | |
|       type: Array,
 | |
|       default: () => []
 | |
|     },
 | |
|     searchData: {
 | |
|       type: Object,
 | |
|       default: () => {}
 | |
|     }
 | |
|   },
 | |
|   methods: {
 | |
|     handleClick(emitKey) {
 | |
|       // emit事件
 | |
|       this.$emit(`${emitKey}`)
 | |
|     }
 | |
|   }
 | |
| 
 | |
| }
 | |
| 
 | |
| </script>
 | |
| <style lang="scss">
 | |
|   .base-search-form{
 | |
|     .el-form-item{
 | |
|       margin-bottom: 0px;
 | |
|     }
 | |
|   }
 | |
| </style>
 |