低代码如何构建响应式布局前端页面

代码,如何,构建,响应,布局,前端,页面 · 浏览次数 : 2727

小编点评

**活字格如何实现页面响应式布局呢?** 活字格通过以下几种方式实现页面响应式布局: 1. **动态设置页面布局:** 活字格可以根据视口的分辨率、浏览器尺寸等因素动态设置页面布局。 2. **使用网格布局:** 活字格使用网格布局来实现页面响应式布局。 3. **设置不同模式的页面布局:** 活字格支持固定模式、自适应模式和范围模式等不同模式的设置,方便用户根据需求选择合适的布局。 4. **利用行列布局:** 活字格可以利用行列布局来实现灵活的布局控制。

正文

本文由葡萄城技术团队于博客园原创并首发
转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。

“你开发的界面为啥在我的屏幕里这么小啊?”

“这个界面为啥在我这里会出现横向滚动条啊?”

大家在进行前端界面开发时,有没有遇到这些类似的问题呢?又是如何解决的呢?

页面响应式

在进行项目交付的场景中,常常会存在项目系统在不同设备,不同屏幕尺寸下使用和展示。因此在开发过程中需要针对此场景做针对性处理。一般来说,在处理这样的问题时,我们需要开发和提供不同的布局,通过检测视口的分辨率,判断当前访问设备的种类,请求不同的页面布局从而提供尺寸较为合适的展示场景。而不同的布局,可以选择提前开发完成,或者采用判断窗口大小的方式动态地调整最终页面来实现效果,业内称之为页面的响应式布局。

不同尺寸下的响应式页面布局

那么,在低代码领域,对于提前设计好的页面元素,是如何实现页面的响应式变化呢?让我们来看一看活字格是如何实践的!

活字格的实践

对于页面的响应式能力,活字格一直在持续的增强。在版本的早期,活字格提供了页面拉伸的模式帮助用户将页面布局更好的适应屏幕的尺寸。而在后续的迭代中,活字格加入了粒度精确到行列的模式设置,通过对行列性质的修改,保证页面可以动态且精确的填充至整个展示屏幕中。

页面拉伸模式

活字格中,可对全局或单个页面设置页面拉伸模式。单个页面设置只在本页面生效,而全局的生效范围扩展到了整个应用。活字格为用户提供了五种拉伸模式,方便用户在不同的场景下进行选择:

  • 无拉伸:页面在浏览器中不会进行拉伸,与设计原型保持一致。
  • 水平拉伸:页面在不同浏览器中随着浏览器尺寸进行水平方向上的拉伸。
  • 垂直拉伸:页面在不同浏览器中随着浏览器尺寸进行垂直方向上的拉伸。
  • 双向拉伸:页面在不同浏览器中随着浏览器尺寸进行水平和垂直方向上的拉伸,使得在充满不同分辨率的浏览器时都具有较好的视觉效果。
  • 等比拉伸(填满宽度):页面将填满浏览器的宽度,再等比对高度进行拉伸

页面拉伸的特性优点在于设置简单,易用;同时也会有些弊端,由于页面拉伸是页面整体元素进行拉伸,那么如果想要实现部分固定部分拉伸的效果就很困难,因此,这个特性在对页面精度强需求的场景就不是很合适了。活字格针对这样的场景,提供了行列模式设置。

行列模式设置

行列模式为活字格的布局设计注入了全新的活力与可能。在了解行列模式之前,我们需要对一个布局有个直接的理解,这就是活字格所采用的网格(Grid)布局。

网格(Grid)布局

网格布局(Grid)是CSS(层叠样式表,为网页添加页面样式的一种计算机语言)布局方案的一种,也是泛用性最广泛的一种。其原理是将网页划分成一个个网格,通过任意组合不同的网格,做出各种各样的布局。

Grid布局示意图

由于网格属于标准的二维布局,因此网格布局将页面划分为“行”与“列”,产生单元格,对单元格的设置与组合,最终形成页面最终的效果。活字格的设计器是类excel风格,所以天生就是一个适应Grid布局的高手。活字格为用户提供了3种设置模式,分别是固定模式、自适应模式和范围模式,通过设置行高、列宽的调节模式为自适应模式或范围模式,可使页面呈现流式布局,使页面的布局更加灵活。

固定模式

固定模式下,行高、列宽为固定的大小,单位为像素,不会随着展示屏幕的变化而变化,如果页面所有被设定了固定模式的行列总像素已经大于了浏览器的宽度/高度,那浏览器中就会出现横向/纵向滚动条。

自适应模式

在活字格中,自适应代表的不是页面自适应,而是组件的自适应。活字格的页面设计是所见即所得的,每一个组件都是通过单元格的组合而形成。当对某个组件设置了自适应之后,组件会根据内部的内容动态的变化自己的高度或宽度,比如文本框,会根据输入的文字内容来动态调节自己的框体大小,附件单元格会按照数据的多少来扩展高度。

范围模式

范围模式的主要作用是充满整个浏览器屏幕,也是想要实现流式布局最为推荐的做法。

活字格中,范围模式提供了按照像素与占比两种方式来设定范围

活字格的范围模式设置界面

上图中的最大值占比,代表的是当且设置的列,在整个页面占据的比例为1份,也就是说,如果整个页面,只有当前列被设置了占比为1,那么只有这一列会填充整个页面。而如果页面中有两列都设置了占比为1,这两列在整个页面中会按照各自占据1/2的范围来填充,如果有一列设置了1份,另一列设置了2份,那么最终的填充效果为设置为1的列占据了1/3,而另外一列占据2/3。

行列自动扩

活字格的每个行列,都可以设置以上3种模式,而占用多行区域的单元格,设置一行或者一列时,这个容器区域内部会自动扩展。比如:表格,图文列表,数据透视表,页面容器单元格,标签页,选项卡等。

多行区域的单元格范围设置

通过设置范围模式达到内容自动填充页面的效果

总结

通过对页面拉伸和行列设置灵活运用,活字格所涉及的应用可以灵活的适应不同尺寸下的展示终端,此外,活字格还提供了移动端的界面,方便用户在移动端下,设计出更为美观灵活的界面。

与低代码如何构建响应式布局前端页面相似的内容:

低代码如何构建响应式布局前端页面

本文由葡萄城技术团队于博客园原创并首发 转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。 “你开发的界面为啥在我的屏幕里这么小啊?” “这个界面为啥在我这里会出现横向滚动条啊?” 大家在进行前端界面开发时,有没有遇到这些类似的问题呢?又是如何解决的呢? 页面

如何在低代码平台中引用 JavaScript ?

引言 在当今快速发展的数字化时代,企业对业务应用的需求日益复杂且多元。低代码开发平台作为一个创新的解决方案,以直观易用的设计理念,打破了传统的编程壁垒,让非技术人员也能轻松构建功能完备的Web应用程序,无需深入编码。这一特性极大地简化了应用开发流程,加速了业务需求转化为实际应用的速度,为企业带来了前

远离勒索病毒,如何在Linux上安装活字格低代码服务管理器?

本文由葡萄城技术团队于博客园原创并首发 转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。 活字格低代码开发平台由可视化设计器和服务管理器构成,开发者使用设计器构建Web应用,测试无误后即可将应用进行打包,并发布到服务管理器上。服务管理器会加载设计器发布的应用

集群部署看过来,低代码@AWS智能集群的架构与搭建方案

为了帮助充分利用AWS的托管服务快速构建起一套集群环境,彻底去掉“单一故障点”,实现最高的可用性,我们准备了**《低代码智能集群@AWS的架构与搭建方案》**看完本文,带你掌握“基于nginx配置服务器集群”。 应用场景 如果你需要解决如下的问题,可以考虑搭建一套活字格@AWS智能集群: 保障系统高

vivo 低代码平台【后羿】的探索与实践

本文主要从前后端分离的低代码方案、自研高性能渲染引擎、高效的可视化配置方案、千亿级内容投放、低代码如何与传统开发共存等五个维度vivo在低代码平台方面的实践经验,其中也会涉及到动态交互如何运用低代码来编排和我们在提高配置效率方面的全面探索。

万物皆可集成资源包!低代码集成系列一网打尽

本文由葡萄城技术团队于博客园原创并首发 转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。 如何花最短的时间、用最少的成本解决客户的企业级应用定制问题? 如何满足数据库集成、Web API集成、第三方软件集成等需求,在如今万物皆可盘的当下,低代码如何用积木大玩

低代码平台如何借助Nginx实现网关服务

摘要:本文由葡萄城技术团队于博客园原创并首发。转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。 前言 在典型的系统部署架构中,应用服务器是一种软件或硬件系统,它承载着应用程序的核心逻辑。它接收客户端的请求并处理相应的业务逻辑、数据操作等任务。应用服务器通常被

低开开发笔记(二):低代码编辑器基本原理

好家伙, 完整代码已开源 https://github.com/Fattiger4399/ph-questionnaire.git 本片我们来讲述 如何将dsl的数据渲染为视图 1.数据格式 dsl: { component: 'div', wid: 0, props: { }, style: {

vivo 游戏中心低代码平台的提效秘诀

本文首先介绍背景与痛点,然后阐述了vivo互联网游戏中心是如何搭建低代码平台,最后展示了低代码平台带来的收益和未来建设方向。

万物皆可集成系列:低代码对接阿里物流API实现快递跟踪

随着各大电商网购平台的发展,快递业已形成一个规模庞大的产业,据统计,全球快递企业已超过千家,而快递查询对于电商平台而言是最基础的功能之一,通过输入快递单号,不用区分具体是哪家快递公司,即可查询到快递的实时状态。目前的主流方法都是调用第三方快递查询接口,下面就介绍一下在活字格中如何调用API接口来进行