当前位置:网站首页>Google AppSheet: 无需编程构建零代码应用
Google AppSheet: 无需编程构建零代码应用
2022-08-04 18:08:00 【林地宁宁】
Google AppSheet: 无需编程构建应用
原文地址:CSDN 博客
本文参考:
文章目录
1. 前言
云原生时代,人与人之间的交流合作变得愈发重要,单单是程序员间的沟通已经不能再满足市场瞬息万变的需求。但是当需求来临时,又不得不竭尽全力去填坑,这种时候心中不禁呐喊:“You can you up, no bee bee”,于是各种低代码和零代码平台应运而生,力求让简单应用的开发变得触手可及。
AppSheet 是 Google 旗下的一个强大的无代码应用开发平台。AppSheet 使普通开发者,从 IT 从业人员到业务用户,都能够使用其易于使用的交互式用户界面创建和定制应用程序。
AppSheet 能在完全零代码的前提下做到:
- 自动执行业务流程,例如订单审批和用户通知
- 借助 Google AI 和机器学习技术,根据用户意图自动构建操作和视图
- 为公民开发人员提供治理以快速构建关键应用
- 构建一个可在台式机、移动设备和平板电脑上使用的应用
- 连接到各种数据源,从 Google 表格到 Salesforce
2. 主要特性
自动化流程并改善协作:
AppSheet Automation 将无代码和 Google AI 相结合,使任何地方的任何人都可以更轻松地自动化业务流程。快速创建具有自动化功能的应用,以充分利用时间和人才。
丰富的数据收集和离线同步:
通过更智能的方式在线上和线下收集数据。AppSheet 会利用您设备的强大功能来添加更有价值的数据,例如 GPS 位置信息、照片、绘图、条形码扫描和字符识别等。预测并自动执行数据收集以简化流程、节省员工时间并提高数据质量。
利用 Google 的 AI 和机器学习技术加快构建速度,从而改善应用质量:
利用自然语言处理 (NLP) 技术在应用中搜索并发出命令,利用计算机视觉技术捕捉和注释图片,同时构建预测模型以学习根据历史应用数据进行归纳 - 全都无需任何机器学习经验。
通过治理功能扩大规模:
IT 人员和普通开发者共同维护组织的应用生态系统的公开范围和控制权。设置政策并自定义团队体验,根据用户角色、员工等因素仅显示相关功能和信息。
3. AppSheet 入门: 如何构建应用
大多数应用创建者已经拥有他们想要构建的应用。通常他们有两个问题:
- 我可以使用 AppSheet 构建此应用吗?
- 我应该如何使用 AppSheet 构建此应用?
在本文中,我们将逐步完成以下示例用例,以解答此问题。
“我有一家建筑公司。我正在构建一组应用程序,以便能够跟踪我们工作现场正在发生的事情。我构建了一个电子表格(Google 表格是我的数据源),其中输入了与特定任务相关的所有数据,在本例中为水涂层。
我的数据列指定需要涂覆的不同区域。例如,列 A 指 A 塔,列 B 指 301 号公寓,列 C 指 B 塔。
我已使用现有的数据填充此表,我的目标是创建一个应用程序,允许主管在验证任务完成后勾选任务框。此外,我希望能够跟踪每位员工每天涂覆的涂料总量,以及所有工作现场的涂装量。
我该如何在 AppSheet 中构建它?
步骤摘要
每个应用程序创建者都应遵循6个步骤:
- 定义实体
- 构建电子表格
- 插入电子表格
- 定义用户体验
- 优化应用行为
- 查看应用安全性
3.1 定义实体
AppSheet 应用程序都是关于数据的。我们从实体及其属性的角度来考虑数据。
每条数据都应归类为一个实体。实体是现实世界中的一组事物 - 在上面的示例中,涉及的四个实体将是员工,工作,位置和客户。
每个实体都有一组标准属性;例如,每个客户都有一个姓名、地址、电话号码和电子邮件地址。实体的所有实例将具有相同类型的属性,但具有不同的值。
这些不同的属性值有助于唯一标识实体的实例。例如,可能具有属性 EmployeeID number
。
最后,实体可以相互关联。在本例中,每个 Job
都对应一个 Customer
,并在一个 Building
中,同时也被分配给一个 Employee
。Job
实体引用实体 Customer
、实体 Building
和实体 Employee
。
3.2 构建电子表格
AppSheet支持 Google Sheets,Microsoft Excel 和 Smartsheet。若要将数据插入 AppSheet,应使用这些平台之一。
所定义的每个实体 (Job
, Employee
, Building
) 都应在连接到 AppSheet 的电子表格中拥有自己的工作表。
在此单个工作表中,实体的不同属性应为列标题。按照该示例,下面显示了工作表如何具有与实体 Customer
的不同属性相对应的列:
有关如何构建电子表格的详细信息,请参阅原文章的数据:要点。
3.3 插入电子表格
若要将数据实际实现到将来的应用中,请在应用编辑器中选择“数据>表”,选择“新建表”,然后查找并选择要使用的数据表:
3.4 定义用户体验
UX(User Experience) 指应用的用户体验。UX 定义描述向应用用户显示的内容及其显示方式(即用户界面)。
视图(View) 是可视化数据的不同方式。AppSheet 编辑器提供日历、卡片组、表格、库、详细信息、地图、图表、仪表板和窗体视图。您可以通过单击 UX 窗口中的特定表来选择视图类型。
在何处查找和启动视图:
视图有两个位置:“主视图(Primary)” 和 “菜单视图(Menu)”。
- 主视图在应用的底部栏中访问,并且最常使用。
- 菜单视图可在应用程序左上角的菜单中访问。这些视图仅偶尔使用。
有关详细信息,请参阅原文的配置在应用中启动视图的位置。
使用表单视图捕获数据:
窗体视图用于从用户捕获数据。在应用的现有视图中,您应该会看到一个编辑操作按钮,点击此按钮可让用户创建新 Job 记录。
您不需要显式创建窗体视图。AppSheet 会自动为允许添加或更新的任何表创建窗体视图。
您可以自定义应用程序徽标,选择颜色主题,定义格式规则等。
有关更多信息,请参见原文 UX:基本信息。
3.5 优化应用行为
该应用程序显示数据,允许用户导航,捕获和添加数据,并将数据与后端电子表格同步。虽然此过程的所有方面都有默认行为,但应用创建者可以修改和优化这些行为。
有四种方法可以优化应用的行为:
- 静态配置(Static configuration)
- 动态配置(Dynamic configuration)
- 行动(Actions)
- 自动化(Automation)
静态配置(Static configuration):
静态配置是最简单的方法。“静态”一词表示此配置对于应用的所有用户和应用中的所有数据都是固定的。每个表中的每一列都有几个静态配置选项。例如,列是只读的还是可由用户编辑的。同样,每个 UX 视图都有几个静态配置选项。例如,库视图中的图像大小或表格视图的排序顺序。
还有各种静态配置选项,用于控制应用是否应脱机工作以及在应用和后端电子表格之间同步数据的频率。这些选项可能会对应用的感知性能产生重大影响。
动态配置(Dynamic configuration):
其他三种方法能力更加强大,但也更复杂。它们都要求您(应用创建者)为应用在运行时的不同情况下,设置不同的行为。当然,这种动态行为比静态配置强大得多。可以为不同的用户、同一表中的不同行,甚至为同一列的不同值指定不同且适当的行为。
对于每个此类决策,您必须以系统所能接受的形式进行定义。在 AppSheet 中,此类动态行为的基本构建块是表达式(或公式)。
关于表达式
在语法和行为方面,AppSheet 表达式与电子表格公式几乎相同。
表达式通常在特定表的行的上下文中定义。例如,表达式 [Status] = "Complete"
可用于筛选表的行,并且仅保留 Status
列中标记为 "Complete"
的行。
表达式可以定义条件、算术表达式、文本操作和各种更复杂的计算的自然组合,例如 AND([Status] = "Complete", [Quantity] > 5)
。
要记住的重要一点是,表达式本身不会导致任何行为,因此是声明式的。它只是定义了一个计算,该计算将在计算时产生一个值。根据表达式的使用位置(请参阅以下部分),其计算值将修改应用的行为。
应用定义中的许多配置接受表达式而不是静态值。例如,可以根据表达式的结果显示或隐藏行的列。同样,可以使用条件格式规则修改用于显示特定列值的颜色。这些规则中的条件是表达式。
表达式的一个重要用途是计算两种类型的虚拟数据:
- 虚拟列:虚拟列不存在于电子表格数据源中,而是使用表达式动态计算生成。大多数情况下,它们的行为类似于常规列。
- 虚拟表(或切片):虚拟表是原始表的虚拟子集,只有一些行和一些列。虚拟表的筛选由表达式定义。大多数情况下,它们的行为类似于常规表。
行动(Actions):
行动是单个操作,表示对应用的最终用户有意义的逻辑步骤。该应用程序的所有默认行为实际上是系统创建的操作(UX 导航,表单编辑,添加新行,拨打电话)的结果。实际上,所有这些系统创建的操作都可以被控制、修改或覆盖。
最简单操作是应用导航操作,这些操作将用户导航至应用内的不同视图(UX 视图),或导航至外部应用(如手机应用或消息应用)。
数据更改操作提供了强大的功能和丰富性。你可以创建自己的操作来反映应用的语义。例如,可以将操作定义为“完成 a”,此操作可能会在内部设置作业,以记录 Job 中两个不同属性的值,然后发送电子邮件给客户。
但是,AppSheet 中的操作不是通过代码实现。它们仅仅涉及简单的声明型的表达式,以用于描述应用的数据和/或表示状态中的所需更改。通过将单个操作组合成单个记录或记录集上的复合操作,可以定义非常强大的行为。
通常情况下,一个动作在应用程序中的执行是作为终端用户与用户界面明确交互的结果(即,点击一个按钮)。事实上,最好是把应用程序的用户界面看作是在等待终端用户的交互事件,然后通过执行与该事件和与该事件相关的数据行绑定的动作来对每个这样的事件作出反应。
有关详细信息,请参阅原文操作:要点。
自动化(Automation):
自动化是最复杂但也最强大。通过自动化,最终用户无需显式触发应用行为。相反,自动化可以指定应按计划或在特定事件发生时(如数据更改)运行的操作。事实上,自动化甚至可以成为最终用户交互的触发器。例如,通过自动化推送通知,通知最终用户某些信息。自动化逻辑可以触发一系列复杂的活动。
在 AppSheet 中,此类自动化是使用机器人定义的。机器人可以在两种不同的环境中执行:
- 在设备上运行的应用内:此类机器人的常见方案包括在设备上按定期计划运行某种类型的数据捕获逻辑(例如,定期记录 GPS 位置)。
- 在 AppSheet 云服务中:此逻辑按计划运行(非常适合定期报告),或者在将每个新的或更新的记录发送到后端电子表格时运行。这种形式的自动化已经得到支持。在我们的示例应用中,很自然地检查作业记录的任何更新,如果作业已完成,则向经理发送电子邮件,其中包含作业的摘要详细信息。
有关更多信息,请参见原文 AppSheet 自动化:要点。
3.6 查看应用安全性
创建应用时,它在最初只有你才能使用。但是,尽快与几个测试用户共享应用是有意义的,以便您获得反馈。在此阶段,重要的是要考虑应用程序的安全性。
AppSheet 提供了各种丰富的安全功能,这些功能以不同的粒度级别提供访问控制。
有关详细信息,请参阅原文安全性:要点。
应用级别的访问控制:
安全性设置中,最重要的是控制谁可以访问该应用程序。在这一小节中,先得问自己一个简单的问题:我会限制对应用程序的访问吗?
如果您在任何业务的内部中使用此应用,或者该应用允许用户更新数据,则答案几乎通常为“是”。只有当你正在创建一个供广泛公众消费的应用程序时,你才会说“不”。
在我们的示例中,正在创建应用程序以用于建筑业务,因此它应该限制对业务员工的访问。在 AppSheet 中,您可以通过要求应用程序用户登录才能使用应用程序来限制访问。
此外,您还提供允许的用户及其电子邮件地址的列表。
UX 级别的访问控制:
某些用户可以访问单个 UX 视图,但对其他用户隐藏。这是通过使用当前用户的标识,来做出动态决策的表达式来实现的。
数据级别的访问控制:
应用程序中的每个表都指定权限——“允许添加”、“删除”和“更新”。此决策可以使用表达式进行动态决策。此外,这种表达式可以基于当前用户的标识,从而导致丰富的权限控制能力。
不同的用户看到不同的数据子集也是一个常见的要求。可以使用应用于数据的每一行的安全筛选器表达式来实现此行级的安全性。
行为级别的访问控制:
还可以使用使用当前用户标识的表达式自定义单个行为和自动化过程。因此,可以个性化应用程序的行为,并且可以以完全数据驱动的方式控制对各种行为的访问。
4. 总结
本文介绍了谷歌公司旗下的无代码自动化平台 AppSheet,并以一个例子描述了 AppSheet 的整体开发流程,并给出基于 AppSheet 在零代码开发中所起的作用。
如果您觉得此文有用,还希望给俺一键三连,搬文不易,笔者不胜感激。(●’◡’●)
边栏推荐
- 【STM32】STM32单片机总目录
- (ECCV-2022)GaitEdge:超越普通的端到端步态识别,提高实用性
- DSPE-PEG-DBCO,DBCO-PEG-DSPE,磷脂-聚乙二醇-二苯并环辛炔科研实验用
- 2019 Haidian District Youth Programming Challenge Activity Elementary Group Rematch Test Questions Detailed Answers
- #yyds干货盘点# 面试必刷TOP101:链表相加(二)
- Thrift installation configuration
- 开发那些事儿:如何通过EasyCVR平台获取监控现场的人流量统计数据?
- 工业元宇宙对工业带来的改变
- Cholesterol-PEG-DBCO,CLS-PEG-DBCO,胆固醇-聚乙二醇-二苯基环辛炔科研试剂
- CAS:385437-57-0,DSPE-PEG-Biotin,生物活性分子磷脂-聚乙二醇-生物素
猜你喜欢
Web端即时通讯技术:WebSocket、socket.io、SSE
网页端IM即时通讯开发:短轮询、长轮询、SSE、WebSocket
悦刻难回巅峰
电源测试系统-ATE电源测试系统-ACDC电源模块测试系统NSAT-8000
Matlab drawing 1
OpenInfra Days China 2022|SelectDB与你共享 Apache Doris 在互联网广告业务中的实践
2019 Haidian District Youth Programming Challenge Activity Elementary Group Rematch Test Questions Detailed Answers
链表的经典入门LeetCode题目
How does the intelligent video surveillance platform EasyCVR use the interface to export iframe addresses in batches?
2022年五一数学建模C题讲解
随机推荐
区间贪心(区间合并)
Flink/Scala - Storing data with RedisSink
2022年五一数学建模C题讲解
CAS:474922-26-4,DSPE-PEG-NH2,DSPE-PEG-amine,磷脂-聚乙二醇-氨基供应
通俗易懂-二维数组只能省略行不能省略列-人话版本
电源测试系统-ATE电源测试系统-ACDC电源模块测试系统NSAT-8000
Interval greedy (interval merge)
The Industrial Metaverse Brings Changes to Industry
Documentary on Security Reinforcement of Network Range Monitoring System (1)—SSL/TLS Encrypted Transmission of Log Data
什么是网站监控,网站监控软件有什么用?
离线同步odps到mysql 中文乱码是因为?mysql已是utf8mb4
DHCP&OSPF组合实验演示(Huawei路由交换设备配置)
基于大学生内卷行为的调查研究
Go language Go language, understand Go language file operation in one article
July 31, 2022 Summary of the third week of summer vacation
单行、多行文本超出显示省略号
localstorage本地存储的方法
unity中实现ue眼球的渲染
使用scikit-learn计算文本TF-IDF值
Create Sentinel high-availability cluster current limiting middleware from -99