news 2026/5/13 16:30:18

大厂在用的低代码工具!只需配置json即可快速生成前端界面的

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
大厂在用的低代码工具!只需配置json即可快速生成前端界面的


  • 💂 个人网站:IT知识小屋
  • 🤟 版权:本文由【IT学习日记】原创、在CSDN首发、需要转载请联系博主
  • 💬 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦

文章目录

      • 简介
      • 技术栈
      • 实现原理
      • 快速上手
      • 开源地址&使用手册
      • 写在最后

简介

amis是由百度开源的一款前端低代码渲染框架,无需懂前端,仅通过配置JSON即可生成各式各样的后台页面,大大降低前端开发门槛和提升了开发效率,且不会受前端技术栈变更的影响,特别适用于构建中后台系统与数据驱动的可视化界面。用户无需深入掌握React、Vue、Webpack等技术,只需专注业务即可快速搭建高质量界面。

主要特点如下:

  • 基于JSON驱动:通过JSON Schema一键生成表单、列表、图表等组件,无需编码即可实现页面渲染

  • 组件库丰富:内置表单、表格、按钮、图表、容器、拖拽等 100+ 常用组件,可满足复杂业务场景

  • 可视化编辑:支持在线Schema编辑器,可实时预览页面效果,便于快速修改与测试

  • 性能稳定:经过百度内部多年实战检验,已支撑数万页面稳定运行

  • 低技术门槛:对前端门外汉友好,非前端背景人员亦可快速上手创建页面

  • 灵活扩展:支持自定义组件混用,在低代码基础上集成自定义业务组件


技术栈

语言框架:TypeScript + React 渲染方式:JSON → Component Schema 渲染 状态管理:MobX + mobx‑state‑tree 脚手架:npm / Lerna / Vite 样式:SCSS 编译工具:Vite 许可证:Apache‑2.0

实现原理

amis的渲染过程是将 json 转成对应的 React 组件。先通过 json 的 type 找到对应的 Component,然后把其他属性作为 props 传递过去完成渲染。

如:一个表单页面来说,如果用 React 组件开发一般长这样:

<Page title="页面标题" subTitle="副标题"> <Form title="用户登录"> <InputText name="username" label="用户名" /> </Form> </Page>

替换成amis实现则仅是:只需要把 json 节点,根据 type 信息自动转成 React Component 即可

{ "type": "page", "title": "页面标题", "subTitle": "副标题", "body": { "type": "form", "title": "用户登录", "body": [ { "type": "input-text", "name": "username", "label": "用户名" } ] } }

快速上手

1、下载依赖SDK,方式有如下2中:

  • 方式1、在开源社区获取最新发行版,解压放入项目即可

  • 方式2、使用 npm i amis 来下载,在 node_modules\amis\sdk 目录里就能找到

2、在html中引入,基于json开发,如下面的一个增删改查界面

{ "title": "浏览器内核对 CSS 的支持情况", "remark": "嘿,不保证数据准确性", "type": "page", "body": { "type": "crud", "draggable": true, "syncLocation": false, "api": "https://3xsw4ap8wah59.cfc-execute.bj.baidubce.com/api/amis-mock/mock2/sample", "keepItemSelectionOnPageChange": true, "autoGenerateFilter": true, "bulkActions": [ { "type": "button", "label": "批量删除", "actionType": "ajax", "api": "delete:https://3xsw4ap8wah59.cfc-execute.bj.baidubce.com/api/amis-mock/mock2/sample/${ids|raw}", "confirmText": "确定要批量删除?" }, { "type": "button", "label": "批量修改", "actionType": "dialog", "dialog": { "title": "批量编辑", "name": "sample-bulk-edit", "body": { "type": "form", "api": "https://3xsw4ap8wah59.cfc-execute.bj.baidubce.com/api/amis-mock/mock2/sample/bulkUpdate2", "body": [ { "type": "hidden", "name": "ids" }, { "type": "input-text", "name": "engine", "label": "Engine" } ] } } } ], "quickSaveApi": "https://3xsw4ap8wah59.cfc-execute.bj.baidubce.com/api/amis-mock/mock2/sample/bulkUpdate", "quickSaveItemApi": "https://3xsw4ap8wah59.cfc-execute.bj.baidubce.com/api/amis-mock/mock2/sample/$id", "headerToolbar": [ "bulkActions", { "type": "button", "label": "重置测试数据", "actionType": "ajax", "size": "sm", "api": "https://3xsw4ap8wah59.cfc-execute.bj.baidubce.com/api/amis-mock/mock2/sample/reset" }, "export-excel", { "type": "tpl", "tpl": "一共有 ${count} 行数据。", "className": "v-middle" }, { "type": "columns-toggler", "align": "right", "draggable": true }, { "type": "drag-toggler", "align": "right" } ], "footerToolbar": [ "statistics", "switch-per-page", "pagination" ], "columns": [ { "name": "id", "label": "ID", "width": 20, "sortable": true, "type": "text", "searchable": { "type": "input-text", "name": "id", "label": "主键", "placeholder": "输入id" } }, { "name": "browser", "label": "Browser", "searchable": { "type": "select", "name": "browser", "label": "浏览器", "placeholder": "选择浏览器", "options": [ { "label": "Internet Explorer ", "value": "ie" }, { "label": "AOL browser", "value": "aol" }, { "label": "Firefox", "value": "firefox" } ] } }, { "name": "platform", "label": "平台", "popOver": { "trigger": "hover", "body": { "type": "tpl", "tpl": "就是为了演示有个叫 popOver 的功能" } }, "sortable": true, "type": "text" }, { "name": "grade", "label": "CSS 等级", "type": "select", "options": [ "A", "B", "C", "D", "X" ] }, { "type": "operation", "label": "操作", "width": 100, "buttons": [ { "type": "button", "actionType": "ajax", "label": "删除", "confirmText": "您确认要删除?", "api": "delete:https://3xsw4ap8wah59.cfc-execute.bj.baidubce.com/api/amis-mock/mock2/sample/$id" } ] } ] } }

开源地址&使用手册

点击下方的【IT学习日记】回复【资源】领取!

如果这篇文章对您有帮助,请一定帮我点个“关注”“点赞”,这对我非常重要。我将会继续推荐更多优质项目和新闻。

写在最后

1000+优质开源项目更新进度:269/1000。如需更多类型优质项目推荐,请在文章后留言。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/13 16:30:07

LangChain技术栈集成:DeepSeek-OCR-2构建智能文档处理流水线

LangChain技术栈集成&#xff1a;DeepSeek-OCR-2构建智能文档处理流水线 1. 为什么传统文档处理流程正在失效 最近帮一家金融企业的合规部门做系统升级时&#xff0c;我亲眼看到他们每天要人工处理300多份PDF合同。一位同事指着屏幕上密密麻麻的表格和扫描件说&#xff1a;“…

作者头像 李华
网站建设 2026/5/11 5:48:31

造相Z-Image文生图模型v2虚拟机部署:VMware完整教程

造相Z-Image文生图模型v2虚拟机部署&#xff1a;VMware完整教程 1. 为什么选择VMware部署Z-Image&#xff1f; 在本地机器上直接运行AI图像生成模型&#xff0c;常常会遇到显卡驱动冲突、CUDA版本不兼容、环境依赖混乱等问题。而VMware虚拟机提供了一个干净、隔离的运行环境&…

作者头像 李华
网站建设 2026/5/11 6:47:28

REX-UniNLU与JDK1.8集成:Java应用智能化

REX-UniNLU与JDK1.8集成&#xff1a;Java应用智能化 1. 为什么Java老系统也需要“听懂人话” 很多企业里跑着十年以上的Java系统&#xff0c;它们稳定、可靠、业务逻辑扎实&#xff0c;但有个共同的短板&#xff1a;面对自然语言输入时显得手足无措。用户在客服后台输入“订单…

作者头像 李华
网站建设 2026/5/11 6:47:57

cv_unet_image-colorization模型在数学建模中的应用探索

cv_unet_image-colorization模型在数学建模中的应用探索 1. 数学建模里那些“灰蒙蒙”的图表&#xff0c;其实可以更鲜活 参加过数学建模竞赛的同学大概都经历过这样的时刻&#xff1a;辛辛苦苦推导出一组关键数据&#xff0c;用Matplotlib画出折线图&#xff0c;结果导出PDF…

作者头像 李华
网站建设 2026/5/11 6:47:28

好用还专业! 自考论文降重神器 —— 千笔·降AIGC助手

在AI技术迅速渗透学术写作领域的当下&#xff0c;越来越多的学生开始借助AI工具提升论文写作效率。然而&#xff0c;随着知网、维普、万方等查重系统不断升级算法&#xff0c;以及Turnitin对AIGC内容的识别愈发严格&#xff0c;AI率超标问题正成为困扰众多自考生的“隐形障碍”…

作者头像 李华