UI库提供了很多组件,组件又带有很多属性,有一些常用属性我们可以记住并且手撸,但是有些不常用的属性,或者需要设置多个属性,这样的情况下写起来就麻烦了,有时候还要打开帮助文档看看属性是怎么设定的,需要设置什么样的属性值。 那么有没有优雅的方式来设置组件的各种属性呢?我做了一个在线小工具,可以方便的设置属性,并且可以实时看到效果。
https://naturefw.gitee.io/nf-rollup-ui-controller/
https://gitee.com/naturefw/nf-rollup-ui-controller
工作量比较大、精力有限,目前仅支持 element-plus 的部分组件,理论上可以支持任何UI库,只是设置属性有点太繁琐了,需要时间进行学习、掌握和理解,把相关属性合在一起,还有调试演示代码等工作。 有没有感兴趣的小伙伴来帮帮忙?
实现方法比较土,就是把需要的组件分个类,再把需要的属性分成两种:基础属性、扩展属性,然后就是力气活了,把各种属性整理出来即可。
主要是看内容,文本、日期、数字很明显的可以分别归类,选择和下拉都是选择类型的,分成两类主要是小分类比较多,分开更清晰一些。
范围类的组件,值的类型是数组,非范围型的组件,值的类型不是数组,在动态改变某属性值的时候,数组和非数组有的时候不能自动变更类型,导致代码出错。
这样就需要把范围类的和非范围类的分开,比如 select 的单选模式和多选模式,只是一个 “multiple” 属性的区别,但是这个属性不能在运行时修改,否则会报错,所以只好分成两个小类。
好吧,其实你不用关心这些。
el-input 可以细分为多个小类:单行文本,多行文本,密码,URL,可选等。 为什么要细分呢?因为不同的小类需要的属性是不同的,细分一下可以缩小备选的属性范围,设置起来更清晰,否则像官网那样,各种属性都堆在一起,还得分辨一下是否是支持某个小类。
比如 “show-word-limit” 仅支持单行文本和多行文本,并不支持其他小类。如果我要设置一个密码组件的属性,那么就不需要显示 “show-word-limit”这个属性,否则看起来就会比较乱。
所以通过细分小类的方式显示需要的属性,避免混淆。
表单里的组件共有的属性:
基本上表单里的组件都需要这几个属性,所以拿出来作为基础属性,一起设置。 扩展属性按照分类分别设置。
其实最大值没有做限制,可以>5
不一一列举了,感兴趣的小伙伴可以看在线演示。 https://naturefw.gitee.io/nf-rollup-ui-controller/
属性设置完毕之后,可以生成template模板代码,以及js里定义的对象,支持json格式。
<el-checkbox-group
v-model="checkboxs"
v-bind="itemProps"
>
<el-checkbox
v-for="item in itemProps.optionList"
:key="'check' + columnId + item.value"
:label="item.value"
:disabled="item.disabled"
>
{{item.label}}
</el-checkbox>
</el-checkbox-group>
const itemProps = reactive({
colName: 'test',
kind: 15,
controlType: 152,
colCount: 0,
isClear: false,
clearable: true,
optionList: [
{
value: '1',
label: '选项1',
disabled: false
},
{
value: '2',
label: '选项2',
disabled: false
},
{
value: '3',
label: '选项3',
disabled: false
},
{
value: '4',
label: '选项4',
disabled: false
}
]
})
{
"colName": "test",
"kind": 15,
"controlType": 152,
"colCount": 0,
"isClear": false,
"clearable": true,
"optionList": [
{
"value": "1",
"label": "选项1",
"disabled": false
},
{
"value": "2",
"label": "选项2",
"disabled": false
},
{
"value": "3",
"label": "选项3",
"disabled": false
},
{
"value": "4",
"label": "选项4",
"disabled": false
}
]
}
为啥要支持json呢?大家可以猜一猜。
时间仓促,可能有一点小bug,还有属性值是对象的情况,暂时还没有支持;属性是组件(比如图标)的情况,支持的也不理想。