vxe-table-demonic
Version:
一个基于 vue 的 PC 端表单/表格组件,支持增删改查、虚拟列表、虚拟树、懒加载、快捷菜单、数据校验、树形结构、打印导出、表单渲染、数据分页、弹窗、自定义模板、渲染器、JSON 配置式...
58 lines (57 loc) • 2.16 kB
JavaScript
import { defineComponent, h, provide, inject } from 'vue';
import XEUtils from 'xe-utils';
import GlobalConfig from '../../v-x-e-table/src/conf';
import { useSize } from '../../hooks/size';
export default defineComponent({
name: 'VxeRadioGroup',
props: {
modelValue: [String, Number, Boolean],
disabled: Boolean,
strict: { type: Boolean, default: function () { return GlobalConfig.radio.strict; } },
size: { type: String, default: function () { return GlobalConfig.radio.size || GlobalConfig.size; } }
},
emits: [
'update:modelValue',
'change'
],
setup: function (props, context) {
var slots = context.slots, emit = context.emit;
var $xeform = inject('$xeform', null);
var $xeformiteminfo = inject('$xeformiteminfo', null);
var xID = XEUtils.uniqueId();
var $xeradiogroup = {
xID: xID,
props: props,
context: context,
name: XEUtils.uniqueId('xegroup_')
};
var radioGroupMethods = {};
useSize(props);
var radioGroupPrivateMethods = {
handleChecked: function (params, evnt) {
emit('update:modelValue', params.label);
radioGroupMethods.dispatchEvent('change', params);
// 自动更新校验状态
if ($xeform && $xeformiteminfo) {
$xeform.triggerItemEvent(evnt, $xeformiteminfo.itemConfig.field, params.label);
}
}
};
radioGroupMethods = {
dispatchEvent: function (type, params, evnt) {
emit(type, Object.assign({ $radioGroup: $xeradiogroup, $event: evnt }, params));
}
};
var renderVN = function () {
return h('div', {
class: 'vxe-radio-group'
}, slots.default ? slots.default({}) : []);
};
Object.assign($xeradiogroup, radioGroupPrivateMethods, {
renderVN: renderVN,
dispatchEvent: dispatchEvent
});
provide('$xeradiogroup', $xeradiogroup);
return renderVN;
}
});