amis中 InputTable Combo InputKV/InputKVS 区别

2024-05-25 20:28

本文主要是介绍amis中 InputTable Combo InputKV/InputKVS 区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

InputTable 与 Combo

input-table  内无法配置formula对每列做复杂逻辑

Combo  可以配置formula对每列数据做复杂逻辑处理         combo中每个选项配置弹窗,可以添加此属性,合并数据  "mergeData": true

Combo    与  InputKVS  / InputKV

combo 多选模式数组[ {}, {} ]      Combo 单选模式时对象 { "text":"1", "select":"a" }

InputKV 是对象 { key : value}     inputKVS 类似InputKV也是对象 { key : { kvs } }, 区别在于InputKV value只能是单组件。而InputKVS value可以是多组件组合。尽量用InputKVS

input-kv 可以自定义输入key的name(底层实现也是基于combo 二者配置可共用).   combo 不可自定义.

InputKVS的valueItems内直接通过组件name进行操作即可,无需加前缀name

{

            "type": "input-kvs",

            "name": "field",

            "addButtonText": "新增字段",

            "keyItem": {

                "label": "字段名",

                "name": "_key"  //用户输入作为name

            },

            "valueItems": [{

                    "type": "input-kvs",

                    "addButtonText": "新增字段",

                    "name": "_value", // 直接将keyItem作为value的key,不再嵌套一层name了, 要生效此valueItems内只能放input-kvs一个组件, 否则就是将_value作为name了,而不是输入值作为name

                    "keyItem": {

                        "label": "字段名",

                        "name": "_key"

                    },

                    "valueItems": [{

                        "type": "switch",

                        "name": "primary",

                        "label": "是否是主键"

                    }]

                }

                // {

                //   "type": "switch",

                //   "name": "primary",

                //   "label": "是否是主键"

                // },

                // {

                //   "type": "formula",

                //   "name": "test",

                //   // "formula": "${primary ? '对' : '错'}" //${}表达式语法,只能放一个表达式. 表达式内逻辑运算  valueItems内直接用组件name,不加前缀!!!!!

                //   "formula": "primary ? '对' : '错'"  //js代码

                // }

            ]

        }

Combo的items内直接通过组件name进行操作即可,无需加前缀name。 默认 Combo 数据域中,每一项会有一个隐藏变量index
。

Combo内元素是单个时,可以使用flat": true 打平,提取值到数组中。[aa, bb]

默认情况下,Combo 内表达项无法获取父级数据域的数据. 默认items内组件是封闭再自己的空间内,互相调用的.

默认不会映射父级数据,可以配置"canAccessSuperData": true开启此特性,配置了该配置项后,添加 Combo 的input-text表单项会自动映射父级数据域的同名变量。但是为了效率,在父级数据域变化的时候,默认 combo 内部是不会进行同步的

我们在 combo 上配置"strictMode": false和"syncFields": ["super_text"],即可实现同步  .   syncFields会导致combo数据域结构中多出一个syncFields配置的字段,尽量避免使用syncField!!!!!

Combo组件嵌套使用时,若加了asyncFields修改同步有时不生效,可能是asyncFields嵌套使用的问题,去掉最外层不影响父级数据映射的asyncFields即可fix.

Combo设置默认值:

1.直接配置combo的value属性:  "value": {   "refX": "1" }

2.配置父级的data属性,然后开启combo的canAccessSuperData,注入默认值:   "data": {   "refX": "1" }

    {

      "type": "select",

      "name": "position.name",

      "label": "连接桩布局",

      "source": {

        "method": "get",

        "url": "/lbserver/api/DictionaryInfo/findOptions?filter[where][dictionaryModel]=ProcessDesign&filter[where][dictionaryModelID]=Common.PortLayoutTpl",

        "cache": 10000

      }

    },

    {

      "type": "combo",

      "name": "position.args",

      "canAccessSuperData": true,

      "strictMode": false,

      "syncFields": [

        "position"

      ],

      "items": [

        {

          "type": "service",

          "schemaApi": {

            "method": "post",

            "url": "/lbserver/api/DictionaryInfo/ProcessDesign/Common.PortLayoutTpl/formByName/${position.name}",   //同步变化

            "sendOn": "this.comType"

          }

        }

      ],

    }

Combo将弹窗中数据回传到items对应的form表单中:(动作setValue+index结合实现)

需要给 combo 设置个 id 属性,用来给事件动作指定目标用。

弹窗按钮配置了数据映射 {comboIndex: "${index}"} 因为 crud 的行数据上也有 index 变量,派送动作时获取 index 变量是 crud 所在行的序号。所以弹出弹窗的时候,先把 combo 的序号赋值给 comboIndex

crud 操作栏里面添加了个按钮,close: true 设置是让动作完成后关闭弹窗。

按钮里面添加了 onEvent 配置,click 时做 setValue 动作,并设置参数 index 为 '${comboIndex}' 值为 ${&}。其中 ${&} 是特殊语法,用来取整个上下数据。

 "actions": [

                                {

                                  "componentId": "thecombo",

                                  "actionType": "setValue",

                                  "args": {

                                    "index": "${comboIndex}",

                                    "value": "${&}"

                                  }

                                }

                              ]

这篇关于amis中 InputTable Combo InputKV/InputKVS 区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1002543

相关文章

Go之errors.New和fmt.Errorf 的区别小结

《Go之errors.New和fmt.Errorf的区别小结》本文主要介绍了Go之errors.New和fmt.Errorf的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考... 目录error的基本用法1. 获取错误信息2. 在条件判断中使用基本区别1.函数签名2.使用场景详细对

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

一文带你迅速搞懂路由器/交换机/光猫三者概念区别

《一文带你迅速搞懂路由器/交换机/光猫三者概念区别》讨论网络设备时,常提及路由器、交换机及光猫等词汇,日常生活、工作中,这些设备至关重要,居家上网、企业内部沟通乃至互联网冲浪皆无法脱离其影响力,本文将... 当谈论网络设备时,我们常常会听到路由器、交换机和光猫这几个名词。它们是构建现代网络基础设施的关键组成

redis和redission分布式锁原理及区别说明

《redis和redission分布式锁原理及区别说明》文章对比了synchronized、乐观锁、Redis分布式锁及Redission锁的原理与区别,指出在集群环境下synchronized失效,... 目录Redis和redission分布式锁原理及区别1、有的同伴想到了synchronized关键字

JAVA覆盖和重写的区别及说明

《JAVA覆盖和重写的区别及说明》非静态方法的覆盖即重写,具有多态性;静态方法无法被覆盖,但可被重写(仅通过类名调用),二者区别在于绑定时机与引用类型关联性... 目录Java覆盖和重写的区别经常听到两种话认真读完上面两份代码JAVA覆盖和重写的区别经常听到两种话1.覆盖=重写。2.静态方法可andro

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

MyBatis中$与#的区别解析

《MyBatis中$与#的区别解析》文章浏览阅读314次,点赞4次,收藏6次。MyBatis使用#{}作为参数占位符时,会创建预处理语句(PreparedStatement),并将参数值作为预处理语句... 目录一、介绍二、sql注入风险实例一、介绍#(井号):MyBATis使用#{}作为参数占位符时,会

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

C++中NULL与nullptr的区别小结

《C++中NULL与nullptr的区别小结》本文介绍了C++编程中NULL与nullptr的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录C++98空值——NULLC++11空值——nullptr区别对比示例 C++98空值——NUL