在iframe内通过JS获取当前iframe本身,以及操作

在iframe内通过JS获取当前iframe本身,以及操作


var fullScreen = document.getElementsByClassName("fullScreen")[0].onclick = function () {
// 获取当前iframe的 src

            var url = location.href;
            var _url = url.split("/");

//获取父页面的所有iframe
            var eles = top.document.getElementsByTagName("iframe");

//循环所有iframe
            for (var i = 0 ; i < eles.length; i++) {
                var ele = eles[i];
                var iframeUrl = ele.src;
                var _iframeUrl = iframeUrl.split("/");
//获取当前页面的iframe
                if (_url[_url.length - 1] == _iframeUrl[_iframeUrl.length - 1]) {

                    // 进行操作
                    if (ele.getAttribute("atr")) {
                        removeEleStyle(ele)
                    } else {
                        addEleStyle(ele)
                    }
                }
            }
        }
// 进行操作
function addEleStyle(ele) {
            ele.setAttribute("atr", "atr");
            ele.style.position = "fixed";
            ele.style.top = "0px";
            ele.style.bottom = "0px";
            ele.style.right = "0px";
            ele.style.zIndex = 9999;
            ele.style.left = "0px";
        }
        function removeEleStyle(ele) {
            ele.setAttribute("atr", "");
            ele.style.position = "";
            ele.style.top = "0px";
            ele.style.bottom = "0px";
            ele.style.right = "0px";
            ele.style.zIndex = 0;
            ele.style.left = "0px";
        }

希望对大家有帮助

JS操作iframe里的元素可以通过以下几个步骤进行: 1. 获取iframe元素:首先,我们需要通过`document.getElementById()`或其他适合的方法获取iframe元素的引用。例如,如果iframe元素的id为"myIframe",我们可以像这样获取它:`var iframe = document.getElementById("myIframe");` 2. 获取iframe的内容窗口:每个iframe都有一个`contentWindow`属性,它表示iframe的内容窗口。通过访问`iframe.contentWindow`,我们可以得到iframe内部的window对象引用。例如:`var iframeWindow = iframe.contentWindow;` 3. 获取iframe内部的文档对象:在获取iframe内容窗口的引用后,我们可以通过`iframeWindow.document`来访问iframe内部的文档对象。例如:`var iframeDocument = iframeWindow.document;` 4. 使用iframe的文档对象进行操作:通过获取iframe内部的文档对象,我们就可以像操作普通的HTML文档一样操作iframe中的元素了。例如,如果我们要获取iframe中id为"myElement"的元素,并改变它的样式,可以通过以下代码实现: ``` var myElement = iframeDocument.getElementById("myElement"); myElement.style.color = "red"; ``` 需要注意的是,由于同源策略的限制,当iframe当前页面不属于同一个域时,我们只能通过以上方法获取iframe元素本身,而无法直接访问其内部的文档对象。为了解决这个问题,可以考虑使用postMessage方法进行跨域通信,或者在iframe的源文件中添加合适的跨域资源共享(CORS)头部。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值