0.0.1 • Published 3 years ago

qiankun-one v0.0.1

Weekly downloads
1
License
MIT
Repository
github
Last release
3 years ago

qiankun-one

Follow 阿里巴巴统一微前端规范的 qiankun 版本

与 qiankun 的关系

19年微前端框架如雨后春笋般出现,在开源界和阿里内部都有着不同的业务实践。同时一些对微前端有定制化需求的部门想快速复用,但技术选型存在很高的门槛,对想要进入的部门成本非常大。

为了解决微前端标准不统一的问题,同时推动微前端技术方向的发展。前端委员会层面横向拉通各部门一同共建落地了微前端标准。qiankun 作为微前端开源项目的先驱部队,为了最大程度的保证用户体验,让用户平滑过渡,落地了 qiankun-one 版本。

Usage

安装依赖

$ npm i qiankun-one --save

开始使用

import { IAppConfig, IAppManifest, IOptions, IApp } from 'qiankun-one'

const appConfig: IAppConfig = {
  name: "wei-micro-app-example1",
  entry: [
    "//wei.alicdn.com/micro-app-example/0.1.0/index.js",
    "//wei.alicdn.com/micro-app-example/0.1.0/index.css"
  ],
  activePath: '/demo1',
  // 传递下发的props
  props: {
    title: 'currentTitle'
  },
  // 根据 string 运行时查找DOM节点
  container: "#root-slave",
}

API

路由配置化规范

import { setup, start } from 'qiankun-one';
import Sandbox from '@ali/sandbox';

setup({
    appConfigs: [{
    name: "wei-micro-app-example1",
    entry: [
      "//wei.alicdn.com/micro-app-example/0.1.0/index.js",
      "//wei.alicdn.com/micro-app-example/0.1.0/index.css"
    ],
    activePath: '/demo1',

    // 传递下发的props
    props: {
      title: 'currentTitle'
    },
   
    // 根据 string 运行时查找DOM节点
    container: "#root-slave",
  }, {
    name: "wei-micro-app-example2",
    entry: {
      "scripts": [
        "//wei.alicdn.com/micro-app-example/0.1.0/chunk-libs.js",
        "//wei.alicdn.com/micro-app-example/0.1.0/index.js"
      ],
      "styles": [
        "//wei.alicdn.com/micro-app-example/0.1.0/chunk-libs.css",
        "//wei.alicdn.com/micro-app-example/0.1.0/index.css"
      ]
    },
    activePath: '/demo2',
  }, {
    name: "wei-micro-app-example3",
    entry: "//wei.alicdn.com/micro-app-example/0.1.0/index.html",
    activePath: '/demo3',
  }],
  options: {
    sandbox: new Sandbox(),
    prefetch: true,

    // 生命周期钩子函数
    beforeMount: (app) => {},
    // ...
  },
})
start();

注册及运行函数规范

配置说明类型是否必填默认值
setup注册 app 微应用函数IConfig[]
start开始运行微应用函数--

IConfig - 微应用全局配置规范

配置说明类型是否必填默认值
appConfigs微应用配置集IAppConfig[]-
options额外的配置IOptions-

IAppConfig - app 配置规范

配置说明类型是否必填默认值
name微应用名称,用以标识一个微应用。string-
entry微应用的资源信息描述。string | [string, string] | <IAppManifest>-
activePath微应用受当前路由影响的激活规则。IActivePath-
container微应用挂载的节点。HTMLElement-
props微应用传入的参数object-

IOptions - 微应用配置规范

配置说明类型是否必填默认值
sandbox是否启用内置的沙箱隔离,或者使用自定义的沙箱实例。boolean | ISandboxfalse
prefetch是否预加载微应用的资源。booleanfalse
activePath微应用受当前路由影响的激活规则。IActivePath-
container微应用挂载的节点。HTMLElement-
props微应用传入的参数object-
beforeMount微应用生命周期 - 加载前---
afterMount微应用生命周期 - 加载后---
beforeUnmount微应用生命周期 -卸载前---
afterUnmount微应用生命周期 - 卸载后---
beforeUpdate微应用生命周期 -更新前---
afterUpdate微应用生命周期 - 更新后---

IAppManifest - entry 配置规范

配置说明类型是否必填默认值
scriptjs 相关资源string[]-
stylescss 相关资源string[]-

手动加载规范

import React, { useEffect, useRef } from 'react'
import { createMicroApp } from 'qiankun-one';
interface IApp extends Required<IAppConfig> {
  load(): void;
  mount(container: HTMLElement, props?: object): void;
  unmount(): void;
  update(props?: object): void;
}
const APP = () => {
  const containerRef: React.MutableRefObject<any> = useRef();
  
  useEffect(() => {
    const WidgetInstance: IApp = createMicroApp({
      name: 'widgetName',
      container: containerRef.current,
      entry: [
        "//wei.alicdn.com/micro-app-example/0.1.0/index.js",
        "//wei.alicdn.com/micro-app-example/0.1.0/index.css"
      ],
    }, {
      sandbox: true,
      prefetch: true
    })
    WidgetInstance.load();
  }, [])
  
  return (<div ref={containerRef}></div>)
}

注册函数规范

配置说明类型是否必填默认值
createMicroApp注册 app 微应用入口IConfig[]

返回实例规范

配置说明类型是否必填默认值
load加载子应用---
mount子应用生命周期 - 装载后触发HTMLElement , Props--
unmount子应用生命周期 - 卸载后触发---
update子应用生命周期 - 更新时触发props--