• 【匠心打造】从0打造uniapp 可视化拖拽设计 c_o 第十篇


    一、click one for uniapp置顶:

                    全部免费开源  (你商业用途也没关系,不过可以告诉我公司名或者项目名,放在官网上好看点。哈哈-_-)

    二、写在之前

    距离上一篇更新已经大约4个月了,公司的事情,自己的一些琐事一直没时间来更新。

    好消息是:最近闲下来一两周基础的框架已经完善的差不多了。剩下的只是复用组件和搭建组件了。

    三、架构方向和定位

    设计端:用于拖拽设计(uniapp实现) 

    服务端:用户实现json转换成页面。(java实现(后续会提供python,go,nodejs),当然最终客户端给的是一个json,也支持任何其他服务端语言对接转换)

    转换的框架库:

    uview2.x (第一个版本会加入)、

    colorui,uni官方的组件框架(后续加入)

    定位:

    1、在线UI拖拽实现 (辅助前端或者后端解决80%的页面问题,最终用户肯定还是会根据页面需求去修修改改。细微调整。)

    2、店铺装修模板

    3、产品设计使用模板 

    四、自定义属性和手写属性

    因为css的属性样式实在太多,该版本不会一个一个展示出来,只会展示常用属性。看着那浩如繁星的属性,还不如自己手写。

    五、设计逻辑和基础属性

    1、控件全部自定义实现

    此处以uswiper举例

    fields.js中引入 

    import uswiper from './compoment/uswiper'//轮播图

    uswiper中显示的就是这个的样式了

    其中怎么显示他的预览样式和方法呢?

    1. uswiper: {
    2. title: "轮播",
    3. tabs: [
    4. {
    5. name: "常用风格", props: [
    6. {
    7. type: "style", value: "1", sources: [
    8. {
    9. label: "默认", value: "1", url: " /d4443b71e13c4fb29023c8a0d187222e.png",
    10. properties: [{ showTitle: false }, { autoplay: true }, { circular: true }, { show_dot: false }, { show_zb: true }, { show_num: false }, { indicatorStyle: "" }, { previousMargin: "" }, { nextMargin: "" }]
    11. },
    12. {
    13. label: "带文字", value: "2", url: " /fe4ddbeda92e498c82b7465b8b5278a2.png",
    14. properties: [{ showTitle: true }, { autoplay: true }, { circular: true }, { show_dot: false }, { show_zb: true }, { show_num: false }, { indicatorStyle: "" }, { previousMargin: "" }, { nextMargin: "" }]
    15. },
    16. {
    17. label: "点位", value: "3", url: "https://dev.mzhkit.com/qyyimgs/f32555a5b024467694a9fa7ad0902ebe.png",
    18. properties: [{ showTitle: false }, { autoplay: true }, { circular: true }, { show_dot: true }, { show_zb: true }, { show_num: false }, { indicatorStyle: "" }, { previousMargin: "" }, { nextMargin: "" }]
    19. },
    20. {
    21. label: "数字", value: "4", url: " 5318817aa6ae4d97b2a44c98e402a6ef.png",
    22. properties: [{ showTitle: false }, { autoplay: true }, { circular: true }, { show_dot: false }, { show_zb: true }, { show_num: true }, { indicatorStyle: "{'right':'5%'}" }, { previousMargin: "" }, { nextMargin: "" }]
    23. },
    24. {
    25. label: "卡片", value: "5", url: " 034d50f2753f4ab9a2313d13a548949c.png",
    26. properties: [{ zb_stype: "1" }, { showTitle: false }, { autoplay: true }, { circular: true }, { show_dot: false }, { show_zb: false }, { show_num: false }, { indicatorStyle: "" }, { previousMargin: "30" }, { nextMargin: "30" }]
    27. },
    28. ]
    29. }
    30. ]
    31. },
    32. {
    33. name: "详细参数", params: true, props: [
    34. {
    35. label: "显示title", field: "showTitle", type: "select", value: false, sources: [
    36. { label: "是", value: true },
    37. { label: "否", value: false }
    38. ]
    39. },
    40. {
    41. label: "自动播放", field: "autoplay", type: "select", value: false, sources: [
    42. { label: "是", value: true },
    43. { label: "否", value: false }
    44. ]
    45. },
    46. {
    47. label: "轮询播放", field: "circular", type: "select", value: true, sources: [
    48. { label: "是", value: true },
    49. { label: "否", value: false }
    50. ]
    51. },
    52. {
    53. label: "显示指标", field: "show_zb", type: "select", value: true, sources: [
    54. { label: "是", value: true },
    55. { label: "否", value: false }
    56. ]
    57. },
    58. {
    59. label: "指标样式", field: "zb_stype", parent_id: "5", type: "select", value: "1", sources: [
    60. { label: "横向", value: "1" },
    61. { label: "点位", value: "2" },
    62. { label: "数字", value: "3" }
    63. ]
    64. },
    65. {
    66. label: "指标位置", field: "indicatorStyle", type: "textarea", value: "", height: "100"
    67. },
    68. {
    69. label: "组件高度", field: "height", value: "130",type:"number", tips: "px"
    70. },
    71. // tips:"{'top':'xrpx/x%','left':'xrpx/x%'...}
    72. ]
    73. },
    74. { name: "样式" },
    75. ]
    76. },

    title:标题

    tabs:右侧有多少个属性面板

    props:属性值(具体的属性值,可自行配置,参考控件本身的属性值)

    最终效果如图所示

    其中控件所需的json格式,点击此处也可以弹出来。也在上述json中进行配置。后端按此json格式返回即可(因为人力记忆有限,这样做之后,后端也方便)。

    后续导出的时候,会按照用户的自定义习配置去导出,例如 click one for uniapp 请求服务端习惯代码是 this.$http.get / post  当然你的习惯可能是 this.xx.xxx 导出也批量替换。当然替换之后,能否运行,可能还需要用户自己在mian.js中 加入自己的代码。

    六、click one for uniapp能做什么?

    能不能导出taro,Flutter er(dart),android(java),ios(swift) 是否可行?在作者看来是可行的。当然需要用户非常非常熟悉这两端的代码,在导出的json中进行转换生成即可(当然效果肯定也不是100%)。

    当然,如果使用者特别精通两端。可以自行配置支持的属性和方式。

    作者swift不是特别精通,理想中的最终版本可能会支持 Flutter ,android ,taro,swift(看发展,实在没这个精力。哈哈。)

    七:关于生态规划和发布时间/收费问题

    作者会默认加入三大框架和一些插件市场比较优秀的好看的模板组件(让用户可免费使用)。

    今年肯定会发布一个初始版本,希望大家踊跃stat,哈哈。

    完全开源,永久免费。

    也会提供服务端搭建好的版本(用git上的源码搭建)线上版本,永久不存在任何社区版和公司版。官网线上版本也和git完全保持一致。

  • 相关阅读:
    6月27日云技术研讨会 | 中央集中架构新车型功能和网络测试解决方案
    MFC 解决Enter回车键和Esc取消键默认关闭窗口的三种方法
    22.3 指针与数组
    浅谈数据中心机房UPS蓄电池在线监测系统研究
    [python] pytest
    强化学习领域有哪些最热门和最有前途的研究课题
    0029__时钟分频原理 - 时钟分频原理详解
    含文档+PPT+源码等]基于SpringBoot的阳光线上交友系统包运行成功]计算机毕业设计Java毕设源码
    HTML 表格及练习
    NSS [西湖论剑 2022]real_ez_node
  • 原文地址:https://blog.csdn.net/lhf214111967/article/details/133517048