1. 嵌入

应用中的仪表盘、图表及应用本身都支持进行嵌入,用户可以根据展示需要进行不同层级的嵌入操作。 应用集市、应用创作中的应用都支持嵌入。

1.1. Iframe嵌入指导

以应用嵌入为例介绍如何进行Iframe嵌入,仪表盘、图表嵌入分享过程与应用嵌入类似,这里不详细展开。

  1. 点击应用右上角的嵌入按钮,选择嵌入本应用。

  2. 显示嵌入窗口,包含嵌入的URL和iframe示例。

  3. 嵌入窗口中的URL可以直接分享,用户可直接用该链接在浏览器中展示。如图所示为使用URL在浏览器展示的效果。可以看出嵌入页面只有刷新、全屏、导出按钮,没有其他功能操作按钮。

  4. 嵌入窗口中iframe提供了在代码中嵌入示例,支持使用各种自定义参数,用户可以通过参数调整嵌入后的展示样式。下图示例是设置嵌入大小为800*600的iframe嵌入后的展示效果。

说明:

  1. 应用、仪表盘嵌入时仅展示刷新、全屏、导出等按钮,不展示PC端等功能按钮。
  2. 图表嵌入时需要先打开图表,然后点击嵌入按钮获取链接内容。
  3. 嵌入时不带入过滤条件。

1.1.1. 嵌入场景自定义参数

应用、仪表盘、图表在嵌入时支持多种自定义参数,用户根据需要设定嵌入参数从而影响嵌入后的展示效果。

嵌入图表参数

参数名称 使用方法示例 描述
noTitle 1. noTitle=true
2. noTitle=false
3. 默认设置
设置是否显示标题:
true 不显示标题
false 显示标题
默认设置,显示标题
titleColor 1.titleColor=rgb(0, 0, 0)
2.titleColor=rgba(0, 0, 0, 1)
3.titleColor=red
4.titleColor=hsl(0,0,0)
设置图表的标题颜色,不支持RGB十六进制颜色设置
chartBackground 1.chartBackground=rgb(0, 0, 0)
2.chartBackground=rgba(0, 0, 0, 1)
3.chartBackground=red
4.chartBackground=hsl(0,0,0)
5.chartBackground=transparent
设置图表的背景颜色,不支持RGB十六进制颜色设置
参数为“transparent”时,图表显示透明背景色

嵌入仪表盘参数

参数名称 使用方法示例 描述
copyright 1. copyright=true
2. copyright=false
3. copyright=其他值时
是否显示头部底部:
true 显示
false 不显示
默认设置显示
background 1.background=rgb(0, 0, 0)
2.background=rgba(0, 0, 0, 1)
3.background=red
4.background=hsl(0,0,0)
仪表盘背景颜色,不支持RGB十六进制颜色设置
padding padding=5 设置边距,单位是像素px
scrollable 1. scrollable=true
2. scrollable=false
3. scrollable=其他值时
仪表盘竖轴滚动条设置:
true,可以滚动
false,不能滚动
其他值,默认设置可以
chartBackground 1.chartBackground=rgb(0, 0, 0)
2.chartBackground=rgba(0, 0, 0, 1)
3.chartBackground=red
4.chartBackground=hsl(0,0,0)
chartBackground=transparent
设置图表背景颜色,不支持RGB十六进制颜色设置
参数为“transparent”时,为透明背景色
chartGap  chartGap=5 设置图表间距,单位是像素px
chartTitleColor 1.chartTitleColor=rgb(0, 0, 0)
2.chartTitleColor=rgba(0, 0, 0, 1)
3.chartTitleColor=red
4.chartTitleColor=hsl(0,0,0)
设置图表标题颜色,不支持RGB十六进制颜色设置
chartAccessible 1. chartAccessible=true
2. chartAccessible=false
3. chartAccessible=其他值时
true 可以打开
false 不可以打开
其他时,默认设置可打开
isMobile name="isMobile" 使用该参数时,表示仪表盘按照移动端样式展示。注意如果仪表盘没有对应的移动端展示样式时,使用该参数会报404错误。

1.2. JS SDK嵌入

Iframe嵌入过程中在浏览器会进行两次渲染,页面加载时间变长。当一个页面嵌入多个图表时,每个图表都要进行两次渲染,导致整个页面加载速度变得很慢,影响页面展示效果。

为了更好地解决仪表盘和图表的嵌入性能问题,系统推出了JS SDK嵌入方式,直接在嵌入页面内绘制仪表盘和图表。当同一页面嵌入多个仪表盘或者图表时,每个嵌入页面只加载一次静态资源,相比iframe嵌入,大大提升了渲染速度。JS SDK嵌入时支持动态调整嵌入页面的样式和交互,嵌入方式更加灵活。JS SDK使用门槛比iframe高,需要嵌入人员熟悉JavaScript。

JS SDK嵌入示例如下,可分为引入sdk.js文件、初始化sdk、嵌入三部分。

<div id="hst__embed"></div>
<script src="https://develop.hengshi.org/assets/sdk.4.3.0.js"></script>
<script>
  window.HsEmbedSDK.init({
    baseUrl: 'https://develop.hengshi.org',
  }, onReady);

  function onReady(loginSuccess) {
    if (!loginSuccess) return;
    window.HsEmbedSDK.EmbedChart(document.querySelector('#hst__embed'), {
      width: "1573",
      height: "948",
      params: {
        app: 126457,
        dashboard: 5,
        chart: 37,
      },
    });
  }
</script>

1.2.1. 引用SDK的js文件

下面示例是引用SDK的js文件,每个环境的SDK的js文件不同。 引用的目的是在嵌入页面的windows域上包含全局变量HsEmbedSDK,为后续绘制嵌入的仪表盘或图表做准备。

<script src="https://develop.hengshi.org/assets/sdk.4.3.0.js"></script>

1.2.2. 初始化SDK

使用HsEmbedSDK.init函数初始化SDK,示例如下。

<script>
  window.HsEmbedSDK.init({
    baseUrl: 'https://develop.hengshi.org',
  }, onReady);

  function onReady(loginSuccess) {
    if (!loginSuccess) return;
    window.HsEmbedSDK.EmbedChart(document.querySelector('#hst__embed'), {
      width: "1573",
      height: "948",
      params: {
        app: 126457,
        dashboard: 5,
        chart: 37,
      },
    });
  }
</script>

初始化时,需要传入两个参数

  • 参数1是object,结构如下。其中baseUrl是系统部署的地址,示例中的https://develop.hengshi.org是一级地址,也支持二级地址。 noAuth表示是否开启认证,默认为true表示开启认证,设置为false时表示跳过认证。
interface SDKConfig {
    baseUrl: string;
    noAuth?: boolean;
}
  • 参数2是回调函数,示例中的onReady是回调函数。

说明: 如果使用jwt认证noAuth需要配置为ture,并且在嵌入的仪表盘或图表中传入jwt参数。示例如下:

  window.HsEmbedSDK.init({
    noAuth: true,
    baseUrl: 'https://develop.hengshi.org',
  }, onReady);
  function onReady(loginSuccess) {
    if (!loginSuccess) return;
    window.HsEmbedSDK.EmbedDashboard(document.querySelector('#hst__embed'), {
      width: window.innerWidth,
      height: window.innerHeight,
      params: {
        app: 125396,
        dashboard: 1,
      },
      location: {
        query: {
          activeAuth: 'jwt-param',
          jwtParam: 'Jpc3MiOiLlj5HooYzogIU6emhlbmdjaHVueGkiLCJzdWIiOiJtYXJzaGFsbCJ9.U1nL2yMcMpJYnE4mU7xDewD22uCyj-o'
        },
      },
    });
  }

1.2.3. 嵌入仪表盘/图表

在引用SDK的js文件、初始化SDK后,开始嵌入应用的仪表盘和图表。

说明
嵌入多个仪表盘和图表时,只需要在第一次嵌入时引用SDK的js文件、初始化SDK。
应用、仪表盘嵌入时仅展示刷新、全屏、导出等按钮,不展示PC端等功能按钮。
图表嵌入时需要先打开图表,然后点击嵌入按钮获取链接内容。
嵌入时不带入过滤条件。
JS SDK初步支持分析应用中仪表盘和图表的嵌入,后续版本会不断扩充支持的嵌入范围。

嵌入仪表盘

使用HsEmbedSDK.EmbedDashboard(Element, DashboardOptions)函数进行仪表盘嵌入,需要传入Element和DashboardOptions两个参数。在仪表盘中点击嵌入图标,选择嵌入本仪表盘,查看嵌入示例。

  • Element为嵌入的DOM元素,可以从嵌入示例中获取。示例中传入的Element为document.querySelector('#hst__embed')

  • DashboardOptions为仪表盘相关参数,结构体如下。

    • useshadowDom:使用shadow DOM来做样式隔离,布尔类型,默认为true,该项为非必填项。
    • width :仪表盘嵌入后的宽度,数值类型,单位是px,该项为必填项。
    • height:仪表盘嵌入后的高度,数值类型,单位是px,该项为必填项。
    • params: 仪表盘所在应用ID和仪表盘ID,可以从嵌入示例中获取,该项为必填项。
    • location:需要在url添加过滤器参数时,可以通过location.query来传入参数,该项为非必填项。
      interface Dashboardoptions {
      useshadowDom?: boolean;
      width: number;
      height:number;
      params:{
      app: number | string;
      dashboard: number | string;
      };
      location?:{
      query?: string | Record<string, any>;
      },
      }
      

嵌入图表

使用HsEmbedSDK.EmbedChart(Element, ChartOptions)函数进行图表嵌入,需要传入Element和ChartOptions两个参数。打开图表点击嵌入图标,查看图表嵌入参考示例。

  • Element为嵌入的DOM元素,可以从嵌入示例中获取。 示例中传入的Element为document.querySelector('#hst__embed')

  • Chartoptions为图表相关参数,结构体如下。

    • useshadowDom:使用shadow DOM来做样式隔离,布尔类型,默认为true,该项为非必填项。
    • width :图表嵌入后的宽度,数值类型,单位是px,该项为必填项。
    • height:图表嵌入后的高度,数值类型,单位是px,该项为必填项。
    • params:图表所在应用ID、仪表盘ID、图表ID,可以从系统提供的嵌入参考示例中获取,该项为必填项。
    • location:需要在url添加过滤器参数时,可以通过location.query来传入参数,该项为非必填项。

      interface Chartoptions{
      useShadowDom?: boolean;
      width: number;
      heiqht:number;
      params:{
      app: number | string;
      dashboard: number | string;
      chart: number | string;
      };
      location?:{
      query?:string | Record<string, any>;
      },
      

清除联动过滤

JS SDK支持使用函数HsEmbedSDK.clearFilters()清除图表之间的联动过滤。调用该函数后,图中所示的联动过滤将清除,图表之间不会产生联动。

results matching ""

    No results matching ""

    应用过滤