前言
描述: 在基本项目中搜索栏、分页组件格式样式几乎是固定的,只是对应的数据不同,由于模块会随着需求的不断增加,可能会导致重复代码越来越多,这时可以用到子组件,需要将相同的模块代码统一封装,提高开发效率和页面统一。(自己的想法,只根据自己需求来说)
需求
实现
子组件(search.vue)
html
<template>
<div class="search-main">
<el-select
class="com com-margin"
v-model="objSearch.searchType"
filterable
placeholder="请选择"
>
<el-option
v-for="item in objSearch.searchKeyOptions"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
<el-input
class="com"
v-model="objSearch.searchValue"
placeholder="请输入搜索值"
></el-input>
<el-cascader
class="com"
:options="objSearch.options"
:props="{ checkStrictly: true }"
clearable
:placeholder="objSearch.placeholder"
v-model="objSearch.status"
></el-cascader>
<el-button @click="search" type="primary" icon="el-icon-search"
>搜索</el-button
>
<el-button @click="refresh" type="primary" icon="el-icon-refresh"
>刷新</el-button
>
<el-button type="primary" icon="el-icon-document" @click="exportExcel"
>导出EXCEL</el-button
>
<el-button class="total" type="primary" icon="el-icon-files"
>{{ objSearch.name }}总数:{{ objSearch.total
}}{{ objSearch.unit }}</el-button
>
</div>
</template>
js
<script>
export default {
name: 'Search',
props: {
objSearch: { type: Object, default: null }
},
methods: {
search () {
let obj = {
searchType: this.objSearch.searchType,
searchValue: this.objSearch.searchValue,
status: this.objSearch.status
}
this.$emit('search', obj)
},
refresh () {
this.$emit('refresh')
},
exportExcel () {
this.$emit('exportExcel')
}
}
}
</script>
css
<style scoped>
.search-main {
width: 100%;
line-height: 4rem;
}
.com {
width: 10rem;
}
.com-margin {
margin-left: 1rem;
}
.total {
float: right;
margin-top: 1rem;
}
</style>
父组件部分主要代码(index.vue)
html(主要代码)
Search 指components注册的标签。 :objSearch 指向子组件传的参数 @refresh、@exportExcel、@search 指子组件触发的方法
<div class="device-sensor-main">
<div class="search">
<Search
:objSearch="objSearch"
@refresh="refresh"
@exportExcel="exportExcel"
@search="search"
></Search>
</div>
</div>
js(主要代码)
<script>
import Search from '@/components/search'
export default {
name: 'SensorList',
components: {
Search
},
data () {
return {
objSearch: {
searchKeyOptions: [
{ label: '传感器编号', value: 'sensorImei' },
{ label: '设备IMEI号', value: 'imei' },
{ label: '医院名称', value: 'hospitalName' }
],
searchType: 'sensorImei',
searchValue: '',
name: '设备',
unit: '台',
total: 0,
placeholder: '传感器状态',
options: [],
status: []
}
}
},
methods: {
search (obj) {
console.log('子组件搜索返回数据:', obj)
},
refresh () {
console.log('刷新')
},
exportExcel () {
console.log('导出')
}
}
}
</script>
css
<style scoped>
.search {
width: 100%;
height: 4rem;
}
.footer {
text-align: center;
}
.el-table .el-table__cell {
padding: 0.3rem 0;
}
</style>
结束!!!
|