UNPKG

vxe-table-demonic

Version:

一个基于 vue 的 PC 端表单/表格组件,支持增删改查、虚拟列表、虚拟树、懒加载、快捷菜单、数据校验、树形结构、打印导出、表单渲染、数据分页、弹窗、自定义模板、渲染器、JSON 配置式...

58 lines (57 loc) 2.16 kB
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; } });