位置: IT常识 - 正文

iframe嵌套其它网站页面及相关知识点详解(iframe嵌套页面点击里面的按钮)

编辑:rootadmin
iframe嵌套其它网站页面及相关知识点详解

推荐整理分享iframe嵌套其它网站页面及相关知识点详解(iframe嵌套页面点击里面的按钮),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:iframe嵌套其他系统页面,iframe嵌套页面传递参数,iframe中嵌套iframe,iframe嵌套页面点击里面的按钮,使用iframe嵌套网页,iframe嵌套页面传递参数,iframe中嵌套iframe,iframe中嵌套iframe,内容如对您有帮助,希望把文章链接给更多的朋友!

在开发过程中会遇到需要 在一个页面中嵌套另外一个页面,就要使用到框架 标签,然后指定src就可以了。

基本语法:

<iframe src="需要展示的网站页面的URL"></iframe>

用法举例:

<!DOCTYPE html><html lang="zh"> <head> <meta charset="utf-8"> <title>框架</title> </head> <body> <iframe src="https://www.csdn.net/?spm=1001.2101.3001.4476"></iframe> </body></html>

运行后效果图: 但是我们需要更好看点的iframe. 我们来看看在iframe中还可以设置些什么属性

属性值frameborder是否显示边框,1(yes),0(no)height框架作为一个普通元素的高度,建议在使用css设置width框架作为一个普通元素的宽度,建议使用css设置。name框架的名称,window.frames[name]时专用的属性。scrolling框架的是否滚动。yes,no,auto。src内框架的地址,可以使页面地址,也可以是图片的地址。srcdoc用来替代原来HTML body里面的内容。sandbox对iframe进行一些列限制,IE10+支持

附加说明: 1. 当frameborder=“0”,表示关闭边框;frameborder=“1”,表示有边框(默认=1),出于实用性方面的原因,最好不用设置该属性,请使用 CSS 来应用边框样式和颜色。

2. 宽高可以是以像素计的高度值(比如 "100),也可以是以包含元素百分比计的高度值(比如 “20%”),注意设置百分比的时候,它的父元素也就是外围必须要指定高度,否则百分比不生效。

3. scrolling默认的是auto,也就是有滚动条。如果要想隐藏iframe出现的滚动条,可以使用scrolling="no"隐藏滚动条。

iframe如何处理宽高和主页面不完美融合问题(calc()方法) 内嵌页面的时候,很容易发现内嵌页面很难和主页面完美融合,那么我们在宽高方面需要用到calc方法:

从字面看我们可以把它理解为一个function函数。其实calc就是英文单词calculate(计算)的缩写;它是一个css3新增的功能,可以用来指定元素的长度,动态计算长度值。

<style> nav{ background-color: antiquewhite; height: 30px; } body,html{ height: 100%; } .ifr{ width: 100%; height: calc(100% - 30px); } </style><body> <nav> <a href="">我是导航栏1</a> <a href="">我是导航栏2</a> <a href="">我是导航栏3</a> </nav> <!-- src 是嵌套页面的网址 --> <!-- frameborder是嵌套页面的一个边距 一般设置为0 --> <iframe src="./fuyemian.html" frameborder="0" class="ifr"></iframe></body>

页面嵌套的效果如下:

我们通常使用iframe最基本的特性,就是能自由操作iframe和父框架的内容(DOM). 但前提条件是同域. 如果跨域顶多只能实现页面跳转window.location.href. 那什么是同域/ 什么是跨域呢? 就是判断你的url首部是否一样,下面会有讲解,这里只是提及。

同域不同域的问题

A:<iframe id="mainIframe" name="mainIframe" src="/main.html" frameborder="0" scrolling="auto" ></iframe>B:<iframe id="mainIframe" name="mainIframe" src="http://www.baidu.com" frameborder="0" scrolling="auto" ></iframe>

使用A时,因为同域,父页面可以对子页面进行改写,反之亦然。 使用B时,不同域,父页面没有权限改动子页面,但可以实现页面的跳转 这里,我们先从简单的开始,当主页面和iframe同域时,我们可以干 些什么。

获取iframe里的内容

主要的两个API就是contentWindow,和contentDocument

iframe.contentWindow, 获取iframe的window对象 iframe.contentDocument, 获取iframe的document对象

这两个API只是DOM节点提供的方式(即getELement系列对象)

var iframe = document.getElementById("iframe1");var iwindow = iframe.contentWindow;var idoc = iwindow.document;console.log("window",iwindow);//获取iframe的window对象console.log("document",idoc); //获取iframe的documentconsole.log("html",idoc.documentElement);//获取iframe的htmlconsole.log("head",idoc.head); //获取headconsole.log("body",idoc.body); //获取body

另外更简单的方式是,结合Name属性,通过window提供的frames获取.

<iframe src ="/index.html" id="ifr1" name="ifr1" scrolling="yes"><p>Your browser does not support iframes.</p></iframe><script type="text/javascript">console.log(window.frames['ifr1'].window);console.dir(document.getElementById("ifr1").contentWindow);</script>

其实window.frames[‘ifr1’]返回的就是window对象,即:

window.frames['ifr1']===window

这里就看你想用哪一种方式获取window对象,两者都行,都可以操控iframe里面的DOM内容。

iframe嵌套其它网站页面及相关知识点详解(iframe嵌套页面点击里面的按钮)

在iframe中获取父级内容

在同域下,父页面可以获取子iframe的内容,那么子iframe同样也能操作父页面内容。在iframe中,可以通过在window上挂载的几个API进行获取.

window.parent //获取上一级的window对象,如果还是iframe则是该iframe的window对象window.top //获取最顶级容器的window对象,即,就是你打开页面的文档window.self //返回自身window的引用。可以理解 window===window.self(脑残)

自适应iframe之网页广告

网页为了赚钱,引入广告是很正常的事了。通常的做法就是使用iframe,引入广告地址就可以了,然后根据广告内容设置相应的显示框。但是,为什么是使用iframe来进行设置,而不是在某个div下嵌套就行了呢? 要知道,广告是与原文无关的,这样硬编码进去,会造成网页布局的紊乱,而且,这样势必需要引入额外的css和js文件,极大的降低了网页的安全性。 这些所有的弊端,都可以使用iframe进行解决。 我们通常可以将iframe理解为一个沙盒,里面的内容能够被top window 完全控制,而且,主页的css样式是不会入侵iframe里面的样式,这些都给iframe的广告命运埋下伏笔。可以看一下各大站点是否都在某处放了些广告,以维持生计 比如:W3School 但,默认情况下,iframe是不适合做展示信息的,所以我们需要对其进行装饰.

自适应iframe

默认情况下,iframe会自带滚动条,不会全屏.如果你想自适应iframe的话: 第一步:去掉滚动条

<iframe src="http://www.baidu.com" id="iframe1" scrolling="no"></iframe>

第二步,设置iframe的高为body的高

var iwindow = iframe.contentWindow;var idoc = iwindow.document;iframe.height = idoc.body.offsetHeight;

另外,还可以添加其它的装饰属性:

属性效果allowtransparencytrue or false ----是否允许iframe设置为透明,默认为falseallowfullscreentrue or false----是否允许iframe全屏,默认为false

看个例子:

<iframe id="google_ads_frame2" name="google_ads_frame2" width="160" height="600" frameborder="0" src="target.html" marginwidth="0" marginheight="0" vspace="0" hspace="0" allowtransparency="true" scrolling="no" allowfullscreen="true"></iframe>

可以直接写在内联里面,也可以在css里面定义,不过对于广告iframe来说,样式写在属性中,是最好的。

iframe安全性探索–防嵌套网页

iframe出现安全性有两个方面,一个是你的网页被别人iframe,一个是你iframe别人的网页,为了防止页面被一些不法分子利用,我们需要做好安全性措施。 最出名的clickhacking就是使用iframe来 拦截click事件。因为iframe享有着click的最优先权,当有人在伪造的主页中进行点击的话,如果点在iframe上,则会默认是在操作iframe的页面。 所以,钓鱼网站就是使用这个技术,通过诱导用户进行点击,比如,设计一个"妹妹寂寞了"等之类的网页,诱导用户点击,但实际结果,你看到的不是"妹妹",而是被恶意微博吸粉。 所以,为了防止网站被钓鱼,可以使用window.top来防止你的网页被iframe.

//iframe2.htmlif(window != window.top){ window.top.location.href = correctURL;}

这段代码的主要用途是限定你的网页不能嵌套在任意网页内。如果你想引用同域的框架的话,可以判断域名。

if (top.location.host != window.location.host) {  top.location.href = window.location.href;}

当然,如果你网页不同域名的话,上述就会报错。 所以,这里可以使用try…catch…进行错误捕获。如果发生错误,则说明不同域,表示你的页面被盗用了。可能有些浏览器这样写是不会报错,所以需要降级处理。 这时候再进行跳转即可。

try{  top.location.hostname; //检测是否出错  //如果没有出错,则降级处理  if (top.location.hostname != window.location.hostname) {    top.location.href =window.location.href;  }}catch(e){  top.location.href = window.location.href;}

这只是浏览器端,对iframe页面的权限做出相关的设置。 我们还可以在服务器上,对使用iframe的权限进行设置。

X-Frame-Options X-Frame-Options是一个相应头,主要是描述服务器的网页资源的iframe权限。目前的支持度是IE8+,有3个选项:

1. X-Frame-Options: DENY 拒绝任何iframe的嵌套请求 2. X-Frame-Options: SAMEORIGIN 只允许同源请求,例如网页为 foo.com/123.php,則 foo.com 底下的所有网页可以嵌入此网页,但是 foo.com 以外的网页不能嵌入 3. X-Frame-Options: ALLOW-FROM http://s3131212.com 只允许指定网页的iframe请求,不过兼容性较差Chrome不支持

X-Frame-Options其实就是将前端js对iframe的把控交给服务器来进行处理。

//jsif(window != window.top){ window.top.location.href = window.location.href;}//等价于 X-Frame-Options: DENY//jsif (top.location.hostname != window.location.hostname) {    top.location.href =window.location.href;}//等价于 X-Frame-Options: SAMEORIGIN

该属性是对页面的iframe进行一个主要限制,不过,涉及iframe的header可不止这一个,另外还有一个Content Security Policy, 他同样也可以对iframe进行限制,而且,他应该是以后网页安全防护的主流。

resolve iframe跨域 iframe就是一个隔离沙盒,相当于我们在一个页面内可以操控很多个标签页一样。如果踩坑的童鞋应该知道,iframe的解决跨域也是很有套套的。 首先我们需要明确什么是跨域。 浏览器判断你跨没跨域,主要根据两个点:一个是你网页的协议(protocol),一个就是你的host是否相同,即,就是url的首部:

window.location.protocol +window.location.host

需要强调的是,url首部必须一样,比如:二级域名或者IP地址,都算是跨域.

//域名和域名对应ip, 跨域http://www.a.com/a.jshttp://70.32.92.74/b.js//统一域名,不同二级域名。 跨域http://www.a.com/a.jshttp://a.com/b.js

对于第二种方式的跨域(主域相同而子域不同),可以使用iframe进行解决。 在两个不同子域下(某一方使用iframe嵌套在另一方), 即: http: //www.foo.com/a.html和http: //script.foo.com/b.html 两个文件中分别加上document.domain = ‘foo.com’,指定相同的主域,然后,两个文档就可以进行交互。

//b.html是以iframe的形式嵌套在a.html中//www.foo.com上的a.htmldocument.domain = 'foo.com';var ifr = document.createElement('iframe');ifr.src = 'http://script.foo.com/b.html';ifr.style.display = 'none';document.body.appendChild(ifr);ifr.onload = function(){var doc = ifr.contentDocument || ifr.contentWindow.document;// 在这里操纵b.htmlalert(doc.getElementsByTagName("h1")[0].childNodes[0].nodeValue);};//script.foo.com上的b.htmldocument.domain = 'foo.com';

默认情况下document.domain 是指window.location.hostname. 你可以手动更改,但是最多只能设置为主域名。 通常,主域名就是指不带www的hostname, 比如: foo.com , baidu.com 。 如果,带上www或者其他的前缀,就是二级域名或者多级域名。通过上述设置,相同的domain之后,就可以进行同域的相关操作。另外还可以使用iframe和location.hash,不过由于技术out了,这里就不做介绍了。

原文链接:https://blog.csdn.net/qq_27009517/article/details/124476405

本文链接地址:https://www.jiuchutong.com/zhishi/287243.html 转载请保留说明!

上一篇:魅族路由器mini怎么设置?使用手机设置魅族路由器mini图文教程(魅族路由器mini刷机)

下一篇:特兰西瓦尼亚的川斯发格拉山公路,罗马尼亚 (© Calin Stan/Shutterstock)(特兰西瓦尼亚的统一)

  • 微信不绑定银行卡可以收转账吗(微信不绑定银行卡可以使用零钱吗)

    微信不绑定银行卡可以收转账吗(微信不绑定银行卡可以使用零钱吗)

  • 小米平板5面部解锁怎么设置(小米平板5有面容解锁)

    小米平板5面部解锁怎么设置(小米平板5有面容解锁)

  • 手机上微博如何查看他人UID(手机上微博如何调时间)

    手机上微博如何查看他人UID(手机上微博如何调时间)

  • 手机关机步数还增加吗(手机关机步数还走吗)

    手机关机步数还增加吗(手机关机步数还走吗)

  • 华为nova7se怎么设置应用锁(华为nova7se怎么添加门禁卡)

    华为nova7se怎么设置应用锁(华为nova7se怎么添加门禁卡)

  • 三星手机充电显示有水(三星手机充电显示有水滴标志)

    三星手机充电显示有水(三星手机充电显示有水滴标志)

  • 图片怎么压缩成文件发给别人(图片怎么压缩成zip)

    图片怎么压缩成文件发给别人(图片怎么压缩成zip)

  • qq小秘密怎么删除(qq小秘密怎么删除回复)

    qq小秘密怎么删除(qq小秘密怎么删除回复)

  • 抖音能隐身登录吗(抖音隐身登录什么意思)

    抖音能隐身登录吗(抖音隐身登录什么意思)

  • 电脑QQ能隐藏会话吗(电脑qq能隐藏会议吗)

    电脑QQ能隐藏会话吗(电脑qq能隐藏会议吗)

  • 应用宝下载的文件在哪(应用宝下载的文件)

    应用宝下载的文件在哪(应用宝下载的文件)

  • opporeno2支持5g网络吗(opporeno2可以用5g)

    opporeno2支持5g网络吗(opporeno2可以用5g)

  • 无线不可上网有感叹号(无线不可上网有感叹号怎么办)

    无线不可上网有感叹号(无线不可上网有感叹号怎么办)

  • 电脑腾讯会议录屏(电脑腾讯会议录制没有声音怎么解决)

    电脑腾讯会议录屏(电脑腾讯会议录制没有声音怎么解决)

  • 耳机进水了,另一个听不到怎么办(耳机进水了,另一只没声)

    耳机进水了,另一个听不到怎么办(耳机进水了,另一只没声)

  • 微信每天删好友上限(微信每天删好友会封号吗)

    微信每天删好友上限(微信每天删好友会封号吗)

  • 广域网的核心设备是(广域网的核心设置是什么)

    广域网的核心设备是(广域网的核心设置是什么)

  • qq钱包实名认证能找回qq吗(qq钱包实名认证怎么更改)

    qq钱包实名认证能找回qq吗(qq钱包实名认证怎么更改)

  • xs和11的区别(xs和11哪个性价比高)

    xs和11的区别(xs和11哪个性价比高)

  • 单反相机是什么(单反相机是什么时候出现的)

    单反相机是什么(单反相机是什么时候出现的)

  • 这么看qq礼物收益(怎样查看qq收到的礼物)

    这么看qq礼物收益(怎样查看qq收到的礼物)

  • iphone11蜂窝网络怎么设置(iphone11蜂窝网络慢)

    iphone11蜂窝网络怎么设置(iphone11蜂窝网络慢)

  • 台式电脑u盘插在哪(台式电脑u盘插在哪个接口)

    台式电脑u盘插在哪(台式电脑u盘插在哪个接口)

  • 数据灾备有哪些功能(数据灾备 rpo)

    数据灾备有哪些功能(数据灾备 rpo)

  • oppoa9通话声音小怎么办(oppor9手机通话音量变小了怎么办)

    oppoa9通话声音小怎么办(oppor9手机通话音量变小了怎么办)

  • 华为nova4e后盖是什么材质(nova 4e后盖多少钱)

    华为nova4e后盖是什么材质(nova 4e后盖多少钱)

  • 如何申请域名(如何申请域名步骤)

    如何申请域名(如何申请域名步骤)

  • i912900ks什么水平(i9 9900ks什么意思)

    i912900ks什么水平(i9 9900ks什么意思)

  • InoRpc.exe进程有什么作用 InoRpc进程是什么文件(rundll32进程很多)

    InoRpc.exe进程有什么作用 InoRpc进程是什么文件(rundll32进程很多)

  • 【产品新体验】CSDN. 云IDE体验与功能使用教程(保姆级教程)(产品体验是什么意思)

    【产品新体验】CSDN. 云IDE体验与功能使用教程(保姆级教程)(产品体验是什么意思)

  • 二手车经纪公司和中介的区别
  • 什么叫做供应链公司
  • 社保阶段性减免延长到年底
  • 哪些费用的进项税可以抵扣
  • 小微小型微利企业减按20%的所得税税率征收企业所得税
  • 生活记账技巧
  • 代办汽车过户手续
  • 购买的地下室管道多能退吗
  • 房屋预售交款怎么交
  • 进项转出后还能转入吗
  • 公司新装宽带怎么做账?
  • 公司之间有哪些关系
  • 土地罚款可以计入成本吗?
  • 公司账户转个人账户用途怎么写
  • 税收滞纳金算不算营业利润
  • 保安服务税目
  • 退票费报销凭证可以在机子上打印吗
  • 勾选认证的发票怎么确认签名
  • 收到财产保险赔款会计分录
  • mac如何重装系统win10
  • 技术服务费进项发票怎么做分录
  • 网络适配器感叹号代码43
  • 清除文件夹exe病毒工具
  • 电脑时间同步不了解决方法
  • PQIBrowser.exe是什么进程 PQIBrowser进程查询
  • html中a标签的作用
  • 进口付汇业务流程
  • 车保险理赔的钱多久到账
  • 工业总产值 工业销售产值
  • 塞巴斯蒂安电影 豆瓣
  • 详解php字符串替换
  • 解决前端跨域问题
  • 小微企业开通社保
  • 微服务框架图
  • 银行回单打回来会计要做什么
  • 工业企业生产费用最基本的分类是
  • 资金结存属于什么会计科目
  • phpcms教程
  • 帝国cms破解授权
  • 固定资产进项税额怎么抵扣
  • 税控盘技术服务费抵扣期限
  • 个人所得税租房专项扣除标准
  • 商贸公司成本大吗
  • 税法的个人所得税
  • 小规模纳税人税收政策2023
  • 往酒吧送酒怎么样
  • 没有发票意味着什么
  • 预付款预缴如何做账
  • 转出未交增值税借方余额表示什么
  • 长期股权投资的账务处理
  • 计提附加税金额
  • 处置子公司利润表怎么合并
  • 显示应退税额就是能退是吗
  • 老板想提取销售怎么办
  • 公司帮别人代缴社保要交税吗
  • 全国统一电子发票查询
  • 律师事务所如何成立
  • 出纳账户怎么设置
  • sqlserver中将varchar类型转换为int型再进行排序的方法
  • 用Win7系统的Syskey命令来设置系统的启动密码
  • ubuntu怎么禁用nouveau
  • win7诊断策略服务未运行是电脑问题还是网络
  • hpdskflt.sys
  • 微软账号重新登录
  • 360对win7支持多久
  • vsftpd教程
  • Win10 Mobile 10586.71截图曝光 修复已知问题
  • opengl metal
  • js兼容ie
  • ssh连不上centos
  • python调用cuda执行加法
  • 变量代码是什么
  • unity安装进度条不动
  • 能用javascript 最终
  • 安卓app控件
  • python日志类
  • 买药开税票多少税率
  • 2020年军人自主择业条件
  • 地税局上班时间是几点
  • 江苏省的发票如何查验真伪
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设