在Power Apps里创建组合筛选器并把值传递给Power公式

本文中我将探索在power app里面创建组合过滤器,并把值传递给Power公式来过滤数据.我使用的是Accounts(样本数据)表来演示,你可以使用自己的数据.控件列表如下:

控件 引用 数据源
Combox Business Account表
Toggle Credit Hold Account表
DropDown(Preview) Relationship Type Account表
Reset 重置控件值 N/A
Table(Preview) Collection Account

整个布局大体如下:

效果如下:

该示例的主要函数是Filter().以下描述来自微软:

Syntax

Filter(Table*, Formula1 [, Formula2, ... ] )

  • Table - Required. Table to search.
  • Formula(s) - Required. The formula by which each record of the table is evaluated. The function returns all records that result in true. You can reference columns within the table. If you supply more than one formula, the results of all formulas are combined with the And function.

注意in和exactin的用法(子字符串匹配).当使用 Combox、DropDown、List 等控件时,这些数据是table类型。因此,例如使用 Combox 时,我会首先考虑in运算符。以下是Account表中的数据,我想过滤业务类型("EMS"、"OEM")。

代码类似于:

vbnet 复制代码
FROM Account WHERE 'Business Type' IN ( Combox.dataset)
//It's not a real code, I want to use T-SQL to explain it.

把整个解释为Power fx公式:

scss 复制代码
Filter(Account, 'Business Type' in Combox.SelectedItems)

或者我们缩小下值的范围,使用ShowColumns()的函数,它将删除其他列并仅返回您想要的列,这里是Value列,注意,即使它只有一列,它的类型依然是Table类。

java 复制代码
Filter(Account, 'Business Type' in ShowColumns(Combox.SelectedItems,Value))

类似地,我们可以组合其他控件,然后把它们的值传递给Power fx公式来实现筛选的效果.以下是详细步骤:

1. 设置Combox的数据源:

ini 复制代码
Items = Choices('Business Type (Accounts)')
IsSearchable = false //default is true.

2. 设置DropDown的数据源:

ini 复制代码
Items = Choices('Relationship Type (Accounts)')DefaultSelectedItems= []

3. 重置控件的OnSelect.

scss 复制代码
OnSelect = Reset(ComboBox1);Reset(DropdownCanvas2);

4. 添加Button,设置OnSelect.

less 复制代码
ClearCollect(
    myAccount,
    RenameColumns(
        ShowColumns(
            Filter(
                Accounts,
                (IsBlank(ComboBox1.SelectedItems) || 'Business Type' in ComboBox1.SelectedItems) 
                And (IsEmpty(DropdownCanvas2.SelectedItems) || 'Relationship Type' in ShowColumns(
                    DropdownCanvas2.SelectedItems,
                    Value
                )) 
                And 'Credit Hold' = Toggle1.Checked
            ),
            'Account Name',
            'Main Phone',
            'Address 1: City',
            'Primary Contact',
            'Credit Limit'
        ),
        name,'Customer Name',
        address1_city,'City',
        creditlimit,'Credit Limit',
        primarycontactid,'Primary Contact',
        telephone1,'Main Phone'
    )
)
相关推荐
中间件XL1 天前
接口(集成)平台设计(一)-服务,接口,数据集和数据源
低代码·集成平台·接口平台
摩尔元数3 天前
2026年汽车仪表工厂选MES,厂商推荐
低代码·汽车·制造·mes
麦聪聊数据3 天前
利用SQL2API模式重构微服务中的数据查询层
数据库·sql·低代码·微服务·架构
云捷配低代码3 天前
低代码平台落地方法论:从试点到推广(二)
低代码·需求分析·数字化·数字化转型
麦聪聊数据3 天前
能源互联网的数据桥梁:构建安全、实时的电力数据共享 API 网关
数据库·sql·安全·低代码
低代码布道师4 天前
教培管家第13讲:课程排课——智能排课算法与自动化生成
低代码·小程序·云开发
低代码布道师5 天前
教培管家第11讲:班级管理——教务系统的“集成枢纽”
低代码·小程序·云开发
加加今天也要加油5 天前
Oinone × AI Agent 落地指南:元数据即 Prompt、BPM 状态机护栏、SAGA 补偿、GenUI
人工智能·低代码·prompt
启效云5 天前
【技术赋能实战】焱蓝智益科技:如何用物联网+自组网打通消防应急通信“最后一公里”?
科技·物联网·低代码·软件开发·低代码开发