Skip to content

pageManager 页面管理器

插件管理器

pageManager 是用于查询当前页面组件实例,并且可以通过页面管理器,跟渲染的组件进行交互

页面管理器是由builder组件创建,并在ready事件返回该对象

通过builder组件 ready事件获取pageManager

vue
<template>
  <div>
    <EBuilder ref="kfb" :pageSchema="pageSchema" @ready="handleReady">
    </EBuilder>

  </div>
</template>
<script lang="ts" setup>
import { ref, onMounted } from 'vue'
import { EBuilder, PageManager, PageSchema } from 'epic-designer'
    
const pageSchema = ref<PageSchema>({
  "schemas": [
    {
      "type": "page",
      "id": "root",
      "label": "页面",
      "children": [
        {
          "label": "表单",
          "type": "form",
          "icon": "epic-icon-daibanshixiang",
          "name": "default",
          "componentProps": {
            "labelWidth": 100,
            "labelCol": {
              "span": 5
            },
            "wrapperCol": {
              "span": 19
            },
            "hideRequiredMark": false,
            "labelPosition": "right",
            "size": "default",
            "requireAsteriskPosition": "left"
          },
          "children": [
            {
              "label": "上传文件",
              "type": "upload-file",
              "icon": "epic-icon-upload",
              "field": "upload",
              "input": true,
              "componentProps": {
                "action": "https://examples.epicjs.cn/epic-mock/common/upload",
                "name": "file",
                "showFileList": true
              },
              "id": "upload-file_by35flst"
            }
          ],
          "id": "form_uknia964"
        }
      ],
      "componentProps": {
        "style": {
          "padding": "16px"
        }
      }
    }
  ],
  "script": "const { defineExpose, getComponent } = this;\n\nfunction test (){\n    console.log('test')\n}\n\n// 通过defineExpose暴露的函数或者属性\ndefineExpose({\n test \n})"
})

function handleReady(pageManager: PageManager) {
  console.log(pageManager)
}

</script>

Methods

find

类型:(queryValue: string, queryField = 'id') => ComponentPublicInstance | undefined

说明:用于获取组件实例,只找到一个组件并返回一个组件

getComponentInstance

类型:(queryValue: string, queryField = 'id') => ComponentPublicInstance | undefined

说明:通过id获取组件实例,与find函数相同,推荐使用find函数

findAll

类型:(queryValue: string, queryField = 'id') => ComponentPublicInstance[]

说明:用于获取所有满足条件的组件实例