Avue自定义表单Select选择框--字典数据使用mysql直接生成json格式数据

1、查询sql 

  SELECT cus.custom_name label,cus.custom_col_name prop,cus.custom_type `type`,
  JSON_ARRAY(GROUP_CONCAT(JSON_OBJECT('label', ite.label, 'value', ite.item_value)))dicData

FROM `cj_cu_custom` cus
LEFT JOIN `cloudx`.`sys_dict` di ON cus.module_id = di.module_id AND                         CONCAT('customer_from_',cus.custom_col_name) = di.`dict_type`
LEFT JOIN `cloudx`.`sys_dict_item` ite ON ite.`dict_type` = di.`dict_type`
WHERE cus.module_id = '4'
GROUP BY cus.`id`
ORDER BY cus.custom_position,cus.id

2、拆解分析

  JSON_ARRAY(GROUP_CONCAT(JSON_OBJECT('label', ite.label, 'value', ite.item_value)))dicData

JSON_ARRAY():将数据生成json数组

JSON_OBJECT():将数据生成json对象

GROUP_CONCAT():生成以逗号拼接的字符串

因为Avue表单的字典项需要以下格式数据: 

我想要获得  [ {id:'333' , name:'小明'} , {} , {} ] 这种格式的数据

1、使用  JSON_ARRAY()生成数组,作为最外层

2、使用 JSON_OBJECT()生成多个对象,因为要把多个对象放入josn数组中,所以使用

GROUP_CONCAT()拼接对象

结果:

["{\"label\": \"单选1\", \"value\": \"dx1\"},{\"label\": \"单选2\", \"value\": \"dx2\"}"]

感觉这种方法生成的josn数据需要再处理一次才能在前端使用,

不知道这个需求有没有其他便捷方法,麻烦留言告知,感谢!!

附言:

Avue2 链接(用于vue2):Avue    ;   Avue3 链接(用于vue3)Avue
        

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值