amis:百度开源的低代码前端框架——简单引入示例。使用原生HTML避免打包部署。

本文档介绍了如何利用百度开源的低代码前端框架amis,实现用户无需前端工程师即可自由更改页面内容、样式和布局的需求。通过引入amis库,与后台交互数据,用户可以通过编辑JSON并保存到数据库来更新页面。虽然涉及到的打包部署问题较为复杂,但通过简单的HTML页面和接口调用,可以实现项目的快速开发和灵活维护。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

amis官方文档:https://baidu.gitee.io/amis/zh-CN/docs/index

首先我们要了解到什么是amis,什么是低代码前端框架。

低代码平台是适用于前端力量薄弱的团队,实现用极少部分的代码去实现需求的一套前端框架

用少量的代码节约开发时间

通过了解后,国内的低代码前端框架很多需要money, amis是百度下的开源框架。

近期遇到一个需求:1.使用低代码开发项目。

                                 2.要求写完的项目更具有自由行,用户可以随意的更改内容,样式和布局等等。

                                 3.要求用户改的时候不用通过前端工程师,直接不懂技术的人也可以更改。

我们可以了解到,需求是一个很简单的需求,开发完成后用户可以随意更改并且不通过前端编写代码,但是难处理的是如果使用框架的情况下(本人比较喜欢Vue和一些开源框架)需要涉及到的是打包部署,这一部分操作如果真的要处理也是有办法处理的只不过有些麻烦。通过挠掉了几根头发的代价想到了一个办法:

        通过HTML,引入amis,与后台沟通两条接口,一条保存数据,一条获取数据,上代码更直观。

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8" />
    <title>amis百度低代码</title>
    <script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1" />
    <meta http-equiv="X-UA-Compatible" content="IE=Edge" />
    <link rel="stylesheet" href="https://houtai.baidu.com/v2/csssdk" />
    <style>
        html,
        body,
        .amiss {
            position: relative;
            width: 100%;
            height: 100%;
            margin: 0;
            padding: 0;
        }
    </style>
</head>
<body>
    <div id="amisId" class="amiss"></div>
    <script src="https://houtai.baidu.com/v2/jssdk"></script>
    <script type="text/javascript">
        (function () {
            let amis = amisRequire('amis/embed')
            $.ajax({
                type: 'GET',
                // 只写了一个简单的原生ajax 实际情况需要注意headers 和 type 
                // 下面两个URL是 :一个获取数据 格式为字符串 JSON.parse转JSON 另一个URL为提交保存新的JSON
                // 思路是 首先获取接口中的数据 data 转成JSON串 渲染到页面 如果需要更改页面上面的配置的话 需要写一个提交页面 去把百度amis上面的例子的JSON复制过去 提交保存到数据库
                // HTML文件可以直接上传到服务器 你通过服务器地址 比如 http://xxx:xx/xx/xx/demo.html  你使用框架的时候只需要把框架搭好路由配置好 iframe引入就可以 
                // 如果后台比较给力的情况下 不需要你单独写HTML 直接后台通过你给的格式生成 到时候只需要返给你一个http链接就可以
                // url:'',
                url: '',
                success: function (result) {
                    console.log(result.data)
                    let amisData = amis.embed('#amisId', JSON.parse(result.data));
                }
            })
        })()
    </script>
</body>
</html>

 整体的思路是:amis的代码展示为JSON格式,我们需要把渲染的JSON存到数据库,每次更改的时候需要用户去amis编辑器去编辑完成生成JSON,重新提交保存一下新的JSON,页面正常渲染。

amis编辑器的地址,使用方法,在下一篇文章。

此版本更新内容包括:Feature :sparkles: 新增 sortBy 和 topAndOther filter (#1378) (#1379) api 新增 responseData 配置 (#1379) 添加季度选择器 Quarter (#1382) Container 支持设置样式 (#1411) 加入 ecStat, Apache ECharts (incubating) 的统计和数据挖掘工具 (#1419) Form 支持 feedback (#1420) 新增仿 antd 主题 (#1421) Enhancement jssdk 支持外部监控路由变化重新切换页面 (#1373) 选择类表单项 selectFirst 跳过 disabled 的选项 (#1393) iconfont 发布到 sdk 里 (#1395) api mock 地址替换 (#1408) Echarts 没数据时显示 loading (#1409) Breaking :翻译文件的 key 不再是中文,如果有修改过英文翻译,需要换成新 key (#1416) (#1418) 拆解 factory.tsx,添加 RootRenderer,并能 处理部分 action, 直接渲染个按钮也能弹窗,发ajax了 (#1425) Text 配置 source 样式优化 (#1429) 更换 autobind,继承时 this 不错乱 (#1433) Bugfix 修复 表单项在不配置 name 的时候,value 属性失效问题 (#1372) 修复 Excel 导出的列顺序依照配置的顺序,而不是数据源 (#1377) 修复 ChartRadios tooltip 问题. (#1378) 修复 位置选择组件在新版百度地图 api 下无法使用问题 (#1381) 修复 表单项有多个的时候,回车不提交问题 (#1387) 修复 helper 中 white-space 不正确问题 (#1390) 修复 Excel 导出不支持嵌套 name 和 tpl 问题 (#1424) 修复 收起状态导航菜单不可点击跳转问题 (#1428) 修复 Checkbox 无 disabled 样式问题 (#1414)amis前端低代码框架是一个低代码前端框架,它使用 JSON 配置来生成页面,可以节省页面开发工作量,极大提升开发前端页面的效率。 目前在百度广泛用于内部平台的前端开发,已有 100+ 部门使用,创建了 3w+ 页面。amis前端低代码框架特点1、不需要懂前端:在百度内部,大部分 amis 用户之前从来没写过前端页面,也不会 JavaScript,却能做出专业且复杂的后台界面,这是所有其他前端 UI 库都无法做到的; 2、不受前端技术更新的影响:百度内部最老的 amis 页面是 4 年多前创建的,至今还在使用,而当年的 Angular/Vue/React 版本现在都废弃了,当年流行的 Gulp 也被 Webpack 取代了,如果这些页面不是用 amis,现在的维护成本会很高; 3、享受 amis 的不断升级:amis 一直在提升细节交互体验,比如表格首行冻结、下拉框大数据下不卡顿等,之前的 JSON 配置完全不需要修改; 4、可以完全使用可视化页面编辑器 来制作页面:一般前端可视化编辑器只能用来做静态原型,而 amis 可视化编辑器做出的页面是可以直接上线的。 5、提供完整的界面解决方案:其它 UI 框架必须使用 JavaScript 来组装业务逻辑,而 amis 只需 JSON 配置就能完成完整功能开发,包括数据获取、表单提交及验证等功能,做出来的页面不需要经过二次开发就能直接上线; 6、内置 100+ 种 UI 组件:包括其它 UI 框架都不会提供的富文本编辑器、条件组合等,能满足各种页面组件展现的需求,而且对于特殊的展现形式还可以通过 自定义组件 来扩充; 7、容器支持无限级嵌套:可以通过组合来满足各种布局需求; 8、经历了长时间的实战考验:amis百度内部得到了广泛使用,在 4 年多的时间里创建了 3 万+ 页面,从内容审核到机器管理,从数据分析到模型训练,amis 满足了各种各样的页面需求,最复杂的页面有超过 1 万行 JSON 配置。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值