130 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<template>
 | 
						|
	<!-- #ifdef H5 -->
 | 
						|
	<thead class="uni-table-thead">
 | 
						|
		<tr class="uni-table-tr">
 | 
						|
			<th :rowspan="rowspan" colspan="1" class="checkbox" :class="{ 'tr-table--border': border }">
 | 
						|
				<table-checkbox :indeterminate="indeterminate" :checked="checked" @checkboxSelected="checkboxSelected"></table-checkbox>
 | 
						|
			</th>
 | 
						|
		</tr>
 | 
						|
		<slot></slot>
 | 
						|
	</thead>
 | 
						|
	<!-- #endif -->
 | 
						|
	<!-- #ifndef H5 -->
 | 
						|
	<view class="uni-table-thead"><slot></slot></view>
 | 
						|
	<!-- #endif -->
 | 
						|
</template>
 | 
						|
 | 
						|
<script>
 | 
						|
import tableCheckbox from '../uni-tr/table-checkbox.vue'
 | 
						|
export default {
 | 
						|
	name: 'uniThead',
 | 
						|
	components: {
 | 
						|
		tableCheckbox
 | 
						|
	},
 | 
						|
	options: {
 | 
						|
		virtualHost: true
 | 
						|
	},
 | 
						|
	data() {
 | 
						|
		return {
 | 
						|
			border: false,
 | 
						|
			selection: false,
 | 
						|
			rowspan: 1,
 | 
						|
			indeterminate: false,
 | 
						|
			checked: false
 | 
						|
		}
 | 
						|
	},
 | 
						|
	created() {
 | 
						|
		this.root = this.getTable()
 | 
						|
		// #ifdef H5
 | 
						|
		this.root.theadChildren = this
 | 
						|
		// #endif
 | 
						|
		this.border = this.root.border
 | 
						|
		this.selection = this.root.type
 | 
						|
	},
 | 
						|
	methods: {
 | 
						|
		init(self) {
 | 
						|
			this.rowspan++
 | 
						|
		},
 | 
						|
		checkboxSelected(e) {
 | 
						|
			this.indeterminate = false
 | 
						|
			const backIndexData = this.root.backIndexData
 | 
						|
			const data = this.root.trChildren.filter(v => !v.disabled && v.keyValue)
 | 
						|
			if (backIndexData.length === data.length) {
 | 
						|
				this.checked = false
 | 
						|
				this.root.clearSelection()
 | 
						|
			} else {
 | 
						|
				this.checked = true
 | 
						|
				this.root.selectionAll()
 | 
						|
			}
 | 
						|
		},
 | 
						|
		/**
 | 
						|
		 * 获取父元素实例
 | 
						|
		 */
 | 
						|
		getTable(name = 'uniTable') {
 | 
						|
			let parent = this.$parent
 | 
						|
			let parentName = parent.$options.name
 | 
						|
			while (parentName !== name) {
 | 
						|
				parent = parent.$parent
 | 
						|
				if (!parent) return false
 | 
						|
				parentName = parent.$options.name
 | 
						|
			}
 | 
						|
			return parent
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
</script>
 | 
						|
 | 
						|
<style lang="scss">
 | 
						|
$border-color: #ebeef5;
 | 
						|
 | 
						|
.uni-table-thead {
 | 
						|
	display: table-header-group;
 | 
						|
}
 | 
						|
 | 
						|
.uni-table-tr {
 | 
						|
	/* #ifndef APP-NVUE */
 | 
						|
	display: table-row;
 | 
						|
	transition: all 0.3s;
 | 
						|
	box-sizing: border-box;
 | 
						|
	/* #endif */
 | 
						|
	border: 1px red solid;
 | 
						|
	background-color: #fafafa;
 | 
						|
}
 | 
						|
 | 
						|
.checkbox {
 | 
						|
	padding: 0 8px;
 | 
						|
	width: 26px;
 | 
						|
	padding-left: 12px;
 | 
						|
	/* #ifndef APP-NVUE */
 | 
						|
	display: table-cell;
 | 
						|
	vertical-align: middle;
 | 
						|
	/* #endif */
 | 
						|
	color: #333;
 | 
						|
	font-weight: 500;
 | 
						|
	border-bottom: 1px $border-color solid;
 | 
						|
	font-size: 14px;
 | 
						|
	// text-align: center;
 | 
						|
}
 | 
						|
 | 
						|
.tr-table--border {
 | 
						|
	border-right: 1px $border-color solid;
 | 
						|
}
 | 
						|
 | 
						|
/* #ifndef APP-NVUE */
 | 
						|
.uni-table-tr {
 | 
						|
	::v-deep .uni-table-th {
 | 
						|
		&.table--border:last-child {
 | 
						|
			// border-right: none;
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	::v-deep .uni-table-td {
 | 
						|
		&.table--border:last-child {
 | 
						|
			// border-right: none;
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
/* #endif */
 | 
						|
</style>
 |