Matebase是一个开源,易上手的BI工具,这里不做太多介绍了。

官网地址:https://www.metabase.com/

解决问题描述:

使用iframe内嵌Metabase公开链接之后,页面样式不美观:

1、Metabase默认有背景色,背景的高度不会因为开启了滚动条就适应高度。

2、如果不成为Metabase的付费用户,所使用的的公开连接左下角会有Powerd by Metabse。(违反Metabase开源约定)

解决方案描述:

此方案能够生效,前提是iframe里面的链接不能跨域,跨域将无法获取iframe内的元素高度。

1、在页面完成渲染之后,获取iframe内的元素高度,动态为iframe设置样式高度。

2、监听浏览器窗口的尺寸变化,动态更新iframe的高度设置(如果单纯变化宽度,此时iframe不会自动增高,没找到宽度跟高度的对应关系,有兴趣你可以自己研究一下)

3、监听左侧菜单导航栏的宽度变化:本项目中,左侧菜单导航栏可以收缩,最小宽度为54px,最大210px。需要根据实际进行调整

使用Matebase构建完成自己的仪表盘之后,点击分享并编辑按钮:

如果什么都不做呢,Matebase显示样式会很难看。如下图:

接下来介绍一下样式优化方案:

1、iframe样式设置如下:

<iframe
id="bdIframe"
ref="myIframe"
src="http://localhost/matebase/public/dashboard/6f47b37b-0f86-4dad-822d-d69440ffe5e2" frameborder="0"
style="width:100%;height: 100%;"
allowtransparency
scrolling="no" ></iframe>

2、iframe高度自适应:

let _this = null;

export default {
name: 'DashboardEditor',
data() {
},
created() {
_this = this;
},
mounted() {
_this = this;
this.adaptIframeHeight();
window.onresize = () => {
const oIframe = document.getElementById('bdIframe');
try {
let iDoc = oIframe.contentDocument || oIframe.document || oIframe.contentWindow;
let cHeight = Math.max(iDoc.body.clientHeight, iDoc.documentElement.clientHeight);
let sHeight = Math.max(iDoc.body.scrollHeight, iDoc.documentElement.scrollHeight);
console.info("cHeight=" + cHeight + ", sHeight=" + sHeight);
let height = Math.max(cHeight, sHeight);
oIframe.style.height = height + 'px';
// 隐藏 Power By MetaBase
// let footerDiv = iDoc.getElementsByClassName("EmbedFrame-footer");
// if (footerDiv[0] !== undefined) {
// footerDiv[0].style.display = 'none';
// }
} catch (e) {
console.error("窗口大小变化时,iframe高度自适应异常!" + e);
oIframe.style.height = '1000px';
}
};
try {
const erd = elementResizeDetectorMaker();
let sidebarWidth = null;
// 监听左侧导航栏的宽度变化
erd.listenTo(document.getElementsByClassName("sidebar-container"), (element) => {
sidebarWidth = element.offsetWidth;
_this.$nextTick(() => {
let addHeight = 210;
// 导航栏收缩最小的时候,加大iframe的高度
if (sidebarWidth === 54) {
const oIframe = _this.$refs.myIframe;
if (undefined !== oIframe) {
console.info(oIframe);
let oldHeight = oIframe.style.height;
if (undefined !== oldHeight && oldHeight !== '100%') {
oIframe.style.height = (Number(oldHeight.replace("px", ""))) + addHeight + 'px';
}
}
}
// 导航栏伸展到最大时,减少iframe的高度
if (sidebarWidth === 210) {
const oIframe = _this.$refs.myIframe;
if (undefined !== oIframe) {
console.info(oIframe);
let oldHeight = oIframe.style.height;
if (undefined !== oldHeight && oldHeight !== '100%') {
oIframe.style.height = (Number(oldHeight.replace("px", ""))) - addHeight + 'px';
}
}
}
})
})
} catch (e) {
console.error("监听左侧导航栏宽度变化异常!" + e);
}
},
methods: {
adaptIframeHeight() {
const oIframe = document.getElementById('bdIframe');
oIframe.onload = () => {
try { // iframe高度自适应
let iDoc = oIframe.contentDocument || oIframe.document || oIframe.contentWindow;
let cHeight = Math.max(iDoc.body.clientHeight, iDoc.documentElement.clientHeight);
let sHeight = Math.max(iDoc.body.scrollHeight, iDoc.documentElement.scrollHeight);
let height = Math.max(cHeight, sHeight);
oIframe.style.height = height + 'px';
// 隐藏 Power By MetaBase
// let footerDiv = iDoc.getElementsByClassName("EmbedFrame-footer");
// if (footerDiv[0] !== undefined) {
// footerDiv[0].style.display = 'none';
// }
} catch (e) {
console.error("iframe高度自适应异常!" + e);
oIframe.style.height = '1000px';
}
};
}
}
}

解决这个问题耗费了好久,所以记录一下。希望能帮到遇到类似问题的同学,加油~

MetaBase使用iframe内嵌到Vue页面样式优化的更多相关文章

  1. 如何根据iframe内嵌页面调整iframe高宽续篇

    接着昨天的工作 如何根据iframe内嵌页面调整iframe高宽 来说,按照文章中说的第二种方法实现代码如下: 实现 A.com/detail/view 页面的iframe代码如下: <ifra ...

  2. Python3.x:selenium获取iframe内嵌页面的源码

    Python3.x:selenium获取iframe内嵌页面的源码 前言 在一些网页中经常会看到ifrmae/frame标签,iframe是嵌入式框架一般用来在已有的页面中嵌入另一个页面,当一个元素在 ...

  3. 关于selenium自动化对iframe内嵌元素的处理

    今天上班闲来无聊,于是来练练自动化,结果碰上了可恶的iframe,楼主,以前也遇到过,但是一直也没搞懂怎么处理的,都是抄别人的代码,今天决定独立解决试试.首先先来认识什么是iframe,它就长下图这样 ...

  4. HTML+CSS教程(二)frameset框架和iframe内嵌

    一.框架 (frameset)1.用<frameset></frameset>代替了<body></body>2.rows设置行的占页面的百分比:col ...

  5. 在iframe内页触发顶层页面body的blur事件

    //在iframe内页触发顶层页面body的blur事件. if (window != top) { $(document.body).click(function () { $(top.docume ...

  6. 如何根据iframe内嵌页面调整iframe高宽

    问题来自于工作的实例,我的一个域名A的页面,有个iframe,它可能内嵌了另一个域名B的页面,也可能内嵌域名C的页面,但是呢,B和C的页面大小是不一样的,特别是高是不一样的高,那么我如何设置ifram ...

  7. iframe内嵌页面——跨域通讯

      <template> <div class="act-form"> <iframe :src="src" ref=" ...

  8. vue页面性能优化方案

    个人在项目中用到的页面性能优化的方式总结. 一.均衡页面加载文件的大小和数量 1.项目中小图片图片转base64,通过工具如webpack进行图片压缩,文件进行压缩混淆等 2.vue-router 懒 ...

  9. 弹出iframe内嵌页面元素到父页面并全屏化

    (注册博客好久了,一直没舍得添砖加瓦,主要是每次想写点东西的时候,随便搜一搜发现都比我总结的都要好,甚感尴尬,但是总是要开始的,所以这就是我的第一篇博客,也绝不会是最后一篇,废话不多说,直接入正题) ...

随机推荐

  1. Luat Inside | 多功能YAP物联网终端机,你不会还不知道吧?

    简洁高效是合宙产品的一个重要特点,合宙的工程师们用Demo取代繁杂的说明书,以便于开发者快速上手. 有没有可能把这个学习的过程变得更有趣,并且把技术入门难度进一步降低?作为一名Luat技术爱好者,我对 ...

  2. 如何优雅的实现Mysql 增删改查,看完你就会了

    接着上期说,上期没写一条sql就把数据查询出来了,那如果要保存或者更新数据怎么办呢?能不能自己写sql呢? 保存数据 @GetMapping("save")//保存数据 publi ...

  3. MySQL 到 ES 数据实时同步技术架构

    MySQL 到 ES 数据实时同步技术架构 我们已经讨论了数据去规范化的几种实现方式.MySQL 到 ES 数据同步本质上是数据去规范化多种实现方式中的一种,即通过"数据迁移同步" ...

  4. Java小工具类

    计时器(秒表),计算程序运行时间用的 public class Stopwatch { private static long startTime=0; private static long end ...

  5. hdu 3397 Sequence operation 线段树 区间更新 区间合并

    题意: 5种操作,所有数字都为0或1 0 a b:将[a,b]置0 1 a b:将[a,b]置1 2 a b:[a,b]中的0和1互换 3 a b:查询[a,b]中的1的数量 4 a b:查询[a,b ...

  6. POJ 1775 Sum of Factorials 数论,基础题

    输入一个小于1000000的正整数,是否能表达成式子:a1!+a2!+a3!+...+an (a1~an互不相等). 因为10!>1000000,所以先打1~10的阶乘表.从a[10]开始递减判 ...

  7. Spring-Redis缓存业务优化(通配符删除、两种自定义缓存时长)

    application.yml配置 spring:    cache:     type: REDIS     redis:       time-to-live: PT300S # 默认缓存秒数   ...

  8. leetcode 数组分成和相等的三个部分

    题目: 给你一个整数数组 A,只有可以将其划分为三个和相等的非空部分时才返回 true,否则返回 false. 形式上,如果可以找出索引 i+1 < j 且满足 (A[0] + A[1] + . ...

  9. Vue3 + TypeScript 开发实践总结

    前言 迟来的Vue3文章,其实早在今年3月份时就把Vue3过了一遍.在去年年末又把 TypeScript 重新学了一遍,为了上 Vue3 的车,更好的开车.在上家公司4月份时,上级领导分配了一个内部的 ...

  10. Java 内存泄漏知多少?

    先看再点赞,给自己一点思考的时间,如果对自己有帮助,微信搜索[程序职场]关注这个执着的职场程序员.我有什么:职场规划指导,技能提升方法,讲不完的职场故事,个人成长经验. 面试的时候内存管理是不是很多面 ...