百度开源的低代码前端框架,支持网页和移动端页面开发(百度前端代码规范)

《开源精选》是我们分享Github、Gitee等开源社区中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的是一个由百度开源的低代码前端框架——amis。

在经历了十几年的发展后,前端开发变得越来越复杂,门槛也越来越高,要使用当下流行的 UI 组件库,你必须懂 npm、webpack、react/vue,必须熟悉 ES6 语法,最好还了解状态管理,比如 Redux,如果没接触过函数式编程,光入门都很费劲,而入门之后会发现它还有巨大的生态,相关的库有 2347 个,很多功能相似,挑选成本高。

然而前端技术的发展不会停滞,等学完这些后可能会发现大家都用 Hooks 了、某个打包工具取代 Webpack了。使用amis只需要简单配置就能完成所有页面开发,你不需要了解 React/Vue、Webpack,甚至不需要很了解 JavaScript,即便没学过 amis 也能猜到大部分配置的作用,对于大部分常用页面,应该使用最简单的方法来实现,甚至不需要学习前端框架和工具。

百度开源的低代码前端框架,支持网页和移动端页面开发(百度前端代码规范)

amis的亮点

  • 不需要懂前端:在百度内部,大部分 amis 用户之前从来没写过前端页面,也不会 JavaScript,却能做出专业且复杂的后台界面,这是所有其他前端 UI 库都无法做到的;
  • 不受前端技术更新的影响:百度内部最老的 amis 页面是 4 年多前创建的,至今还在使用,而当年的 Angular/Vue/React 版本现在都废弃了,当年流行的 Gulp 也被 Webpack 取代了,如果这些页面不是用 amis,现在的维护成本会很高;
  • 享受 amis 的不断升级:amis 一直在提升细节交互体验,比如表格首行冻结、下拉框大数据下不卡顿等,之前的 JSON 配置完全不需要修改;
  • amis 内置大量组件,包括了富文本编辑器、代码编辑器、diff、条件组合、实时日志等业务组件,绝大部分中后台页面开发只需要了解 amis 就足够了;还可以通过 自定义组件 来扩充组件,实际上 amis 可以当成普通 UI 库来使用。

百度开源的低代码前端框架,支持网页和移动端页面开发(百度前端代码规范)

低代码可视化编辑器

amis的定位是一个低代码的前端框架,所以这里我们只介绍低代码部分,如果你想使用纯JSON配置来完成页面开发,那么请查看一下文档说明,当然你也可以使用90%低代码 10%代码开发的混合模式,既提升了效率,又不失灵活性。

注意:

1.目前 amis-editor 未开源,但可以免费使用(包括商用)

2.要使用编辑器必须熟悉 React

1. 在项目中使用amis-editor

安装依赖

npm i amis-editor

使用方法

import {Editor} from 'amis-editor';render() { return ( <Editor {...props} /> )}

属性说明:

  • value: any 值,amis 的json 配置。
  • onChange: (value: any) => void。 当编辑器修改的时候会触发。
  • preview?: boolean 是否为预览状态。
  • autoFocus?: boolean 是否自动聚焦第一个可编辑的组件。
  • plugins 插件类集合

2. 添加自定义组件

加自定义编辑器的方式有两种:

  • registerEditorPlugin 注册全局插件。
  • 不注册,但是调用 <Editor> 的时候时候通过 plugins 属性传入。

效果都一样,重点还是怎么写个 Plugin,示例:

import {BasePlugin} from 'amis-editor';export class MyRendererPlugin extends BasePlugin { rendererName = 'my-renderer'; // 暂时只支持这个,配置后会开启代码编辑器 $schema = '/schemas/UnkownSchema.json'; // 用来配置名称和描述 name = '自定义渲染器'; description = '这只是个示例'; // tag,决定会在哪个 tab 下面显示的 tags = ['自定义', '表单项']; // 图标 icon = 'fa fa-user'; // 用来生成预览图的 previewSchema = { type: 'my-renderer', target: 'demo' }; // 拖入组件里面时的初始数据 scaffold = { type: 'my-renderer', target: '233' }; // 右侧面板相关 panelTitle = '自定义组件'; panelControls = [ { type: 'tabs', tabsMode: 'line', className: 'm-t-n-xs', contentClassName: 'no-border p-l-none p-r-none', tabs: [ { title: '常规', controls: [ { name: 'target', label: 'Target', type: 'text' } ] }, { title: '外观', controls: [] } ] } ];}

定义好 plugin 后,可以有两种方式启用

// 方式 1,注册默认插件,所有编辑器实例都会自动实例话。import {registerEditorPlugin} from 'amis-editor';registerEditorPlugin(MyRendererPlugin);// 方式2,只让某些编辑器启用() => ( <Editor plugins={[MyRendererPlugin]} />)

示例只做了简单的说明,可用属性还有很多,具体还是先看 npm 包里面的 .d.ts 文件。

3. 编辑器效果

  • 网页版

百度开源的低代码前端框架,支持网页和移动端页面开发(百度前端代码规范)

  • 移动端

百度开源的低代码前端框架,支持网页和移动端页面开发(百度前端代码规范)

  • 拖拽组件

百度开源的低代码前端框架,支持网页和移动端页面开发(百度前端代码规范)

  • 查看代码

百度开源的低代码前端框架,支持网页和移动端页面开发(百度前端代码规范)

从网页到移动端,包括App、小程序等,amis可以满足的页面需求,但在一些特殊场景,比如有些页面追求个性化的视觉效果,amis 就不适用,实际上绝大部分前端 UI 组件库也都不适合,只能定制开发。更多有关amis的内容可自行前往阅读。

开源地址:https://gitee.com/baidu/amis

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2024年1月15日 上午9:34
下一篇 2024年1月15日 上午9:50

相关推荐

  • 酒钢集团oa办公系统登录

    酒钢集团oa办公系统登录 随着企业规模的不断扩大和业务的不断拓展,企业信息化建设已经成为企业发展的重要组成部分。酒钢集团作为大型企业,其oa办公系统登录已经成为了企业管理中不可或缺…

    科研百科 2024年11月5日
    8
  • 这些项目管理实际问题,你遇到过几个(这些项目管理实际问题,你遇到过几个问题)

    大家好,我是老原。 我做了这么久的内容,给大家分享了很多干货、工具还有行业的内容。 今天的文章汇总了粉丝们来私信我的一些实际工作问题,不知道这些问题你熟不熟悉,是否也遇到过? 当然…

    科研百科 2023年9月5日
    163
  • 科研机构工作思路

    科研机构工作思路 随着科技的不断发展,科研机构已经成为推动科技进步的重要力量。在科研机构的发展中,思路是至关重要的。下面,我们将探讨科研机构工作思路。 一、科研机构工作思路的概述 …

    科研百科 2024年11月26日
    1
  • 昆明员工管理系统项目

    昆明员工管理系统项目 随着企业规模的不断扩大,昆明员工管理系统的项目成为了许多企业都需要关注的话题。这个项目可以帮助企业更好地管理员工信息,提高工作效率,减少错误率。本文将介绍昆明…

    科研百科 2024年12月26日
    6
  • 山东大学李术才科研项目

    山东大学李术才科研项目: 探索基于虚拟现实的人机交互方式 近年来,随着虚拟现实技术的不断发展,虚拟现实已经成为人们日常生活的一部分。在虚拟现实技术的应用中,人机交互方式也得到了很大…

    科研百科 2024年8月3日
    45
  • 大型中文论文网站

    大型中文论文网站: 学术创新与文化传承 随着互联网技术的发展,大型中文论文网站成为了人们获取学术信息的重要渠道。这些网站提供了大量的学术论文和研究成果,不仅为学术界提供了重要的资源…

    科研百科 2024年12月5日
    0
  • 软件定制开发对比模板开发的优势-深圳浩太软件(定制开发和模板的区别)

    一、软件定制开发与模板开发的概念 软件定制开发指的是现有软件系统不能满足用户需求,根据用户要求进行定制开发,以满足特定应用场景的需求。模板开发是指采用模板的方式快速开发软件,经过简…

    科研百科 2023年3月20日
    202
  • 项目管理和项目进度管理

    项目管理和项目进度管理是项目经理必须掌握的核心技能。这两个方面的管理对于项目的成功至关重要。本文将介绍项目管理和项目进度管理的概念、方法和实践。 一、项目管理 项目管理是指通过计划…

    科研百科 2024年7月15日
    32
  • 剑桥大学最新研究成果(5月剑桥大学科研项目)

    5月是剑桥大学一年中最热闹的季节。在这个月份,学校众多科研项目 begin 并开始进行。这些项目涉及各个领域,从自然到人文,从科技到艺术,涵盖了学校的所有研究领域。 剑桥大学的科研…

    科研百科 2024年4月2日
    92
  • 科研项目发论文的要求是什么科研项目发论文的要求是什么

    科研项目发论文的要求是什么 科研项目的发表是许多科学家和研究人员的主要目标之一。通过将研究成果转化为可阅读的论文,研究人员可以展示他们的工作,并为学术界和工业界提供有价值的信息。然…

    科研百科 2024年9月11日
    30