|
@@ -35,6 +35,12 @@ export default defineComponent({
|
|
return props.clearable && !props.disabled && !isEmpty.value
|
|
return props.clearable && !props.disabled && !isEmpty.value
|
|
})
|
|
})
|
|
|
|
|
|
|
|
+ onMounted(() => {
|
|
|
|
+ if (props.initValue) {
|
|
|
|
+ initValueChange(props.initValue)
|
|
|
|
+ }
|
|
|
|
+ })
|
|
|
|
+
|
|
/* 打开弹窗 */
|
|
/* 打开弹窗 */
|
|
const onFocus = (e: FocusEvent) => {
|
|
const onFocus = (e: FocusEvent) => {
|
|
if (props.automaticDropdown && !visible.value) {
|
|
if (props.automaticDropdown && !visible.value) {
|
|
@@ -100,6 +106,18 @@ export default defineComponent({
|
|
emit('change', selectLabel.value)
|
|
emit('change', selectLabel.value)
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ /* initValue 改变 */
|
|
|
|
+ const initValueChange = (value: any | Array<any>) => {
|
|
|
|
+ if (props.initValue) {
|
|
|
|
+ // 处理回显数据
|
|
|
|
+ if (props.multiple) {
|
|
|
|
+ selectLabel.value = value as Array<any>
|
|
|
|
+ } else {
|
|
|
|
+ selectLabel.value = value[props.labelKey] as any
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
/* 分页改变事件 */
|
|
/* 分页改变事件 */
|
|
const paginationChange = (data: number) => {
|
|
const paginationChange = (data: number) => {
|
|
pageIndex.value = data
|
|
pageIndex.value = data
|
|
@@ -108,17 +126,20 @@ export default defineComponent({
|
|
|
|
|
|
/* 表格请求完成 */
|
|
/* 表格请求完成 */
|
|
const tableDone = () => {
|
|
const tableDone = () => {
|
|
- if (props.multiple) {
|
|
|
|
- nextTick(() => {
|
|
|
|
- const newTableData = tableRef.value?.getTableData().tableData
|
|
|
|
- newTableData?.forEach(item => {
|
|
|
|
|
|
+ nextTick(() => {
|
|
|
|
+ const newTableData = tableRef.value?.getTableData().tableData
|
|
|
|
+ newTableData?.forEach(item => {
|
|
|
|
+ if (props.multiple) {
|
|
const temp =
|
|
const temp =
|
|
Array.isArray(selectLabel.value) &&
|
|
Array.isArray(selectLabel.value) &&
|
|
selectLabel.value.find(x => x[props.valueKey] === item[props.valueKey])
|
|
selectLabel.value.find(x => x[props.valueKey] === item[props.valueKey])
|
|
temp && tableRef.value?.setCheckboxRow(item, true)
|
|
temp && tableRef.value?.setCheckboxRow(item, true)
|
|
- })
|
|
|
|
|
|
+ } else {
|
|
|
|
+ const temp = item[props.valueKey] === props.modelValue
|
|
|
|
+ temp && tableRef.value?.setRadioRow(item)
|
|
|
|
+ }
|
|
})
|
|
})
|
|
- }
|
|
|
|
|
|
+ })
|
|
}
|
|
}
|
|
|
|
|
|
/* 请求数据 */
|
|
/* 请求数据 */
|
|
@@ -150,6 +171,14 @@ export default defineComponent({
|
|
const updateModelValue = (value: any) => {
|
|
const updateModelValue = (value: any) => {
|
|
emit('update:modelValue', value)
|
|
emit('update:modelValue', value)
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ watch(
|
|
|
|
+ () => props.initValue,
|
|
|
|
+ () => {
|
|
|
|
+ initValueChange(props.initValue as object | Array<any>)
|
|
|
|
+ }
|
|
|
|
+ )
|
|
|
|
+
|
|
return {
|
|
return {
|
|
popoverRef,
|
|
popoverRef,
|
|
tableRef,
|
|
tableRef,
|