Umi4集成阿里低代碼框架lowcode-engine實現(xiàn)
前言
最近準備研究下阿里低代碼框架lowcode-engine, 官方Demo是提供好的腳手架,由于我們的框架使用的是umi,官方文檔提供了一些教程,在此記錄下在umi4集成lowcode-engine.
實現(xiàn)
搭建umi4項目
1.通過官方文檔的快速開始,我們可以快速創(chuàng)建出項目
先找個地方建個空目錄
mkdir myapp && cd myapp
通過官方工具創(chuàng)建項目, 這里我們采用pnpm包管理工具
$ pnpm dlx create-umi@latest ? Install the following package: create-umi? (Y/n) · true ? Pick Npm Client ? pnpm ? Pick Npm Registry ? taobao Write: .gitignore Write: .npmrc Write: .umirc.ts Copy: layouts/index.tsx Write: package.json Copy: pages/index.tsx Copy: pages/users.tsx Copy: pages/users/foo.tsx > @ postinstall /private/tmp/sorrycc-vylwuW > umi setup info - generate files
創(chuàng)建完成后,安裝依賴, 執(zhí)行 pnpm dev
就可以看到我們的項目啟動起來了。
集成lowcode-engine
- 引入UMD包, 我們在
.umirc.ts
中配置externals,styles和scripts
externals: { 'react': 'var window.React', 'react-dom': 'var window.ReactDOM', 'prop-types': 'var window.PropTypes', '@alifd/next': 'var window.Next', '@alilc/lowcode-engine': 'var window.AliLowCodeEngine', '@alilc/lowcode-editor-core': 'var window.AliLowCodeEngine.common.editorCabin', '@alilc/lowcode-editor-skeleton': 'var window.AliLowCodeEngine.common.skeletonCabin', '@alilc/lowcode-designer': 'var window.AliLowCodeEngine.common.designerCabin', '@alilc/lowcode-engine-ext': 'var window.AliLowCodeEngineExt', '@ali/lowcode-engine': 'var window.AliLowCodeEngine', 'moment': 'var window.moment', 'lodash': 'var window._', }, styles: [ 'https://alifd.alicdn.com/npm/@alilc/lowcode-engine@latest/dist/css/engine-core.css', 'https://g.alicdn.com/code/lib/alifd__next/1.23.24/next.min.css', 'https://alifd.alicdn.com/npm/@alifd/theme-lowcode-light/0.2.0/next.min.css', 'https://alifd.alicdn.com/npm/@alilc/lowcode-engine-ext@latest/dist/css/engine-ext.css' ], scripts: [ { src: 'https://g.alicdn.com/code/lib/react/18.0.0/umd/react.development.js', defer: false, }, { src: 'https://g.alicdn.com/code/lib/react-dom/18.0.0/umd/react-dom.development.js', defer: false, }, { src: 'https://g.alicdn.com/code/lib/prop-types/15.7.2/prop-types.js', defer: false, }, { src: 'https://g.alicdn.com/platform/c/react15-polyfill/0.0.1/dist/index.js', defer: false, }, { src: 'https://g.alicdn.com/platform/c/lodash/4.6.1/lodash.min.js', defer: false, }, { src: 'https://g.alicdn.com/code/lib/moment.js/2.29.1/moment-with-locales.min.js', defer: false, }, { src: 'https://g.alicdn.com/code/lib/alifd__next/1.23.24/next.min.js', defer: false, }, { src: 'https://alifd.alicdn.com/npm/@alilc/lowcode-engine@latest/dist/js/engine-core.js', defer: false, }, { src: 'https://alifd.alicdn.com/npm/@alilc/lowcode-engine-ext@latest/dist/js/engine-ext.js', defer: false, }
- 我們使用lowcode-enginey引擎提供的init進行初始化,
init()
內(nèi)部會調(diào)用ReactDOM.render()
函數(shù),這樣初始化有些弊端。一些內(nèi)容沒有辦法與外部的 React 組件進行通信,也就沒有辦法在一些自定義的 plugin 中獲取 redux 上的全局數(shù)據(jù)等內(nèi)容,但也有好處,就是低代碼引擎比較獨立,后期可以拆出供多個項目使用。
我們參考官方提供的Demo的入口文件。在我們這里封裝成一個LowcodeEditor
組件。
import { init, plugins } from '@alilc/lowcode-engine'; import { useEffect } from 'react'; import registerPlugins from './plugin'; import './global.less'; export default function LowcodeEditor() { useEffect(() => { const preference = new Map(); preference.set('DataSourcePane', { importPlugins: [], dataSourceTypes: [ { type: 'fetch', }, { type: 'jsonp', }, ], }); (async function main() { await registerPlugins(); console.log('first-2') init( document.getElementById('engine-container')!, { // designMode: 'live', // locale: 'zh-CN', enableCondition: true, enableCanvasLock: true, // 默認綁定變量 supportVariableGlobally: true, // simulatorUrl 在當 engine-core.js 同一個父路徑下時是不需要配置的?。?! // 這里因為用的是 alifd cdn,在不同 npm 包,engine-core.js 和 react-simulator-renderer.js 是不同路徑 simulatorUrl: [ 'https://alifd.alicdn.com/npm/@alilc/lowcode-react-simulator-renderer@latest/dist/css/react-simulator-renderer.css', 'https://alifd.alicdn.com/npm/@alilc/lowcode-react-simulator-renderer@latest/dist/js/react-simulator-renderer.js', ], requestHandlersMap: { fetch: async () => {} } }, preference, ); })(); }, []); return <div id='engine-container' style={{backgroundColor: 'red'}}></div>; }
這里只是入口組件的初始化,組件內(nèi)部還有很多內(nèi)容,我們重Deom中copy出來。比如plugin
,assets.josn
,schem.json
等,這里不做過多的介紹,里面的內(nèi)容好多,后續(xù)我們一邊學習,一邊慢慢拆解,分享。
- 使用
LowcodeEditor
組件,在我們需要的地方直接導入,使用就行
import yayJpg from '../assets/yay.jpg'; import LowcodeEditor from '@/components/lowcode-editor2'; export default function HomePage() { return ( <div style={{height: '100%'}}> <LowcodeEditor /> </div> ); }
4.訪問頁面
結束語
代碼已上傳到github,請查看mi4-lowcode-app。
以上就是Umi4集成阿里低代碼框架lowcode-engine實現(xiàn)的詳細內(nèi)容,更多關于Umi4集成lowcode-engine的資料請關注腳本之家其它相關文章!
相關文章
微信小程序 時間格式化(util.formatTime(new Date))詳解
這篇文章主要介紹了微信小程序 時間格式化(util.formatTime(new Date))詳解的相關資料,這里附實例,一目了然很容易解決,需要的朋友可以參考下2016-11-11JavaScript實現(xiàn)余額數(shù)字滾動效果
這篇文章主要介紹了JavaScript實現(xiàn)余額數(shù)字滾動效果,將傳入的帶滾動的n位數(shù)字拆分成每一個要滾動的數(shù),然后動態(tài)的創(chuàng)建裝著滾動到每一位相應數(shù)字的容器,然后放入傳入的目標容器中,更多詳細內(nèi)容,一起進入下面文章學習吧2021-12-12JavaScript實現(xiàn)一個Promise隊列小工具
這篇文章主要介紹了JavaScript實現(xiàn)一個Promise隊列小工具,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-08-08jQuery單頁面文字搜索插件jquery.fullsearch.js的使用方法
jquery.fullsearch.js是一款基于Bootstrap文字搜索插件,可以幫助您快速搜索到當前頁面所包含的指定文字,并定位到所在位置2020-02-02