iframe嵌套跨域grafana,前端如何自定义隐藏模块

问题:grafana 通过 kiosk=tv 或 kiosk 设置的模式并不能完全满足开发需求。如图现在我们需要将红色框出的功能全部隐藏,但保留 时间、缩小区域、刷新频率的功能。从图一转变为图二的样子

图一

图二

解决方式:修改grafana代码和本地代码。我们这里grafana是直接使用的window的包,代码结构如图

修改本地代码,其中my-iframe是grafana的容器

document.getElementById('my-iframe').onload = function(){
	document.getElementById('my-iframe').contentWindow.postMessage({showMenu:false},'*')
};

修改 grafana/public/views/index.html,添加如下代码

    window.addEventListener("message", receiveMessage, false);
    function receiveMessage(event) {
      if (event.data.showMenu === false) {
        if (document.querySelector('sidemenu')) {
          document.querySelector('sidemenu').style.display = 'none';
        }
        var str_css = ".sidemenu{display:none} .navbar-buttons--actions{display:none} .navbar-page-btn{display:none} .navbar-button--tv{display:none}";
        var style = document.createElement("style");
        style.type = "text/css";
        style.innerHTML = str_css;
        document.getElementsByTagName("HEAD").item(0).appendChild(style);
      }
    }

其中 str_css 就是想要隐藏的元素的css 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值