1. 嵌入
应用中的仪表盘、图表及应用本身都支持进行嵌入,用户可以根据展示需要进行不同层级的嵌入操作。 应用集市、应用创作中的应用都支持嵌入。
1.1. Iframe嵌入指导
以应用嵌入为例介绍如何进行Iframe嵌入,仪表盘、图表嵌入分享过程与应用嵌入类似,这里不详细展开。
点击应用右上角的嵌入按钮,选择嵌入本应用。
显示嵌入窗口,包含嵌入的URL和iframe示例。
嵌入窗口中的URL可以直接分享,用户可直接用该链接在浏览器中展示。如图所示为使用URL在浏览器展示的效果。可以看出嵌入页面只有刷新、全屏、导出按钮,没有其他功能操作按钮。
嵌入窗口中iframe提供了在代码中嵌入示例,支持使用各种自定义参数,用户可以通过参数调整嵌入后的展示样式。下图示例是设置嵌入大小为800*600的iframe嵌入后的展示效果。
说明:
- 应用、仪表盘嵌入时仅展示刷新、全屏、导出等按钮,不展示PC端等功能按钮。
- 图表嵌入时需要先打开图表,然后点击嵌入按钮获取链接内容。
- 嵌入时不带入过滤条件。
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 ""
衡石文档
- 产品功能一览
- 发布说明
- 新手上路
- 安装与启动
- 系统管理员手册
- 数据管理员手册
- 分析人员手册
- 数据查看员手册
- 数据服务
- 最佳实践
- 衡石分析平台 API 手册
- 附录