Amis 是基于 React 的開箱即用的 UI 庫,能夠快速構建出數據驅動的界面。而 Vue 是另一個流行的前端框架,同樣能夠用來構建數據驅動的界面。雖然兩者最初的思想和語法不盡相同,但在當前的前端框架生態環境下,兩者也可以很好的結合使用。
在使用 Amis 和 Vue 的過程中,最常見的需求就是需要將使用 Amis 渲染的界面放在 Vue 中。Amis 提供了通過包裹 Vue 的方式實現這一需求的方式,具體可以參考如下代碼:
import AmisRenderer from 'amis/lib/components/Renderer';
import Vue, { CreateElement } from 'vue';
Vue.component('amis-render', {
props: {
schema: Object,
args: Object
},
render(h: CreateElement) {
return h(AmisRenderer, {
props: {
schema: this.schema,
env: this.args?.env || {},
data: this.args?.data || {},
}
});
}
});
通過以上代碼,我們現在就可以在 Vue 文件中使用<amis-render>
自定義標簽來渲染 Amis 頁面了。在使用的過程中,我們可以為<amis-render>
傳遞必要的參數,方便地渲染自己需要的組件。
除了在 Vue 中使用 Amis,我們也可以將 Vue 的組件嵌入到 Amis 的頁面中。同樣是通過一個包裹的方式實現,具體看下面的代碼:
import { RendererProps } from 'amis/lib/factory';
import Vue, { VNode } from 'vue';
Vue.config.productionTip = false;
export { Vue };
export function vueRender(p: RendererProps, renderer: any, h?: (tag: any, data: any, children: any) =>VNode) {
let dom: HTMLElement = p.dom;
if (!dom) {
dom = document.createElement('div');
Object.assign(dom.style, { padding: '10px' });
p.dom = dom;
}
const props = {
...p,
children: p.body,
};
return new Vue({
data: {
props: p,
},
render(h: any) {
return h(renderer, { props }, p.body.map((child: any) =>vueRender(child, renderer, h)));
}
}).$mount(dom);
}
上述代碼定義了兩個方法:vueRender 和 Vue。我們首先需要在組件中注冊 Vue,然后使用 vueRender 把對應的 Vue 組件渲染到 Amis 的頁面中。
最后需要注意的是,除了上述的兩種實現方式,我們還可以使用 Amis 自帶的 Vue 組件庫來更快速地實現數據驅動的頁面構建。不管選擇哪種方式,Amis 和 Vue 的結合使用可以大大增加前端開發的效率,降低維護成本,推進 web 前端開發的進程。