2026-01-12 16:29:53 +08:00
|
|
|
Component({
|
|
|
|
|
options: { multipleSlots: true },
|
|
|
|
|
/**
|
|
|
|
|
* 组件的属性列表
|
|
|
|
|
*/
|
|
|
|
|
properties: {
|
2026-01-14 16:54:47 +08:00
|
|
|
mode: { type: String, value: "single" },
|
|
|
|
|
title: { type: String, value: "请选择" },
|
|
|
|
|
options: { type: Array, value: [] },
|
|
|
|
|
value: { type: null, value: [] },
|
2026-01-12 16:29:53 +08:00
|
|
|
},
|
|
|
|
|
observers: {
|
|
|
|
|
"value,mode": function (v, m) {
|
|
|
|
|
if (m == "multiple") {
|
|
|
|
|
this.setData({ val: Array.isArray(v) ? [...v] : [] });
|
|
|
|
|
} else {
|
|
|
|
|
this.setData({ val: v });
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 组件的初始数据
|
|
|
|
|
*/
|
|
|
|
|
data: {
|
|
|
|
|
visible: false,
|
|
|
|
|
val: [] as any[] | string | number,
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 组件的方法列表
|
|
|
|
|
*/
|
|
|
|
|
methods: {
|
|
|
|
|
click() {
|
|
|
|
|
this.setData({ visible: true });
|
|
|
|
|
},
|
|
|
|
|
close() {
|
|
|
|
|
this.setData({ visible: false });
|
|
|
|
|
},
|
|
|
|
|
radioChange(e: any) {
|
2026-01-14 16:54:47 +08:00
|
|
|
this.triggerEvent("change", { value: e.detail.value });
|
|
|
|
|
this.setData({ val: e.detail.value, visible: false });
|
2026-01-12 16:29:53 +08:00
|
|
|
},
|
|
|
|
|
checkboxChange(e: any) {
|
|
|
|
|
this.setData({ val: e.detail.value });
|
|
|
|
|
},
|
|
|
|
|
ok() {
|
|
|
|
|
this.setData({ visible: false });
|
|
|
|
|
this.triggerEvent("change", { value: this.data.val });
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
|