企业网站,个人博客等WordPress网站以及其他语言网站开发定制需求加QQ详聊。

iframe的初步认识

JavaScript笔记 码云 38℃ 0评论
目录
[隐藏]

一直以来iframe都是比较有争议的话题,有人认为,iframe是能耗最高的一个元素,也有人认为iframe安全性太差等等。虽然大家这么说让我无法反驳,但是iframe其强大的功能是不容忽视的,当我的领导和我说不让用iframe的时候,我就很是纳闷!现在很多大的邮箱网站也在用iframe,为了一探iframe的神秘,我决定为大家介绍一下iframe。

Iframe的基本概念

我们最简单的引用,就是iframe直接直接在页面嵌套iframe标签指定src就可以了。

<iframe src="demo_iframe_sandbox.htm"></iframe>

当然,iframe哈有很多好的属性,一起来看一下:

1.frameborder:是否显示边框,1(yes),0(no)

2.height:框架作为一个普通元素的高度,建议在使用css设置。

3.width:框架作为一个普通元素的宽度,建议使用css设置。

4.name:框架的名称,window.frames[name]时专用的属性。

5.scrolling:框架的是否滚动。yes,no,auto。

6.src:内框架的地址,可以使页面地址,也可以是图片的地址。

7.srcdoc,用来替代原来HTMLbody里面的内容。但是IE不支持,不过也没什么卵用

8.sandbox:对iframe进行一些列限制,IE10+支持

我们通常使用iframe最基本的特性,就是能自由操作iframe和父框架的内容(DOM).但前提条件是同域.如果跨域顶多只能实现页面跳转window.location.href.那什么是同域/什么是跨域呢?  同域不同域的问题:

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,和contentDocumentiframe.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的document
        console.log("html",idoc.documentElement);//获取iframe的html
        console.log("head",idoc.head);  //获取head
        console.log("body",idoc.body);  //获取body

实际情况如:

iframe的初步认识

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

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

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

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

这里就看你想用哪一种方式获取window对象,两者都行,不过本人更倾向于第二种使用frames[xxx].因为,字母少啊喂~然后,你就可以操控iframe里面的DOM内容。

  在iframe中获取父级内容

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

举个栗子:

iframe中获取父级内容

ok,获取了之后,我们就可以进行相关操作了。在同域的iframe中,我们可以巧妙的使用iframe的黑科技来实现一些trick.

  iframe的轮询

iframe长轮询

如果写过ajax的童鞋,应该知道,长轮询就是在ajax的readyState=4的时,再次执行原函数即可。这里使用iframe也是一样,异步创建iframe,然后reload,和后台协商好,看后台哥哥们将返回的信息放在,然后获取里面信息即可.这里是直接放在body里.

var iframeCon = docuemnt.querySelector('#container'),
		text; //传递的信息
	var iframe = document.createElement('iframe'),
		iframe.id = "frame",
		iframe.style = "display:none;",
		iframe.name="polling",
		iframe.src="target.html";
	iframeCon.appendChild(iframe);
	iframe.onload= function(){
		var iloc = iframe.contentWindow.location,
			idoc  = iframe.contentDocument;
		setTimeout(function(){
			text = idoc.getElementsByTagName('body')[0].textContent;
			console.log(text);
			iloca.reload(); //刷新页面,再次获取信息,并且会触发onload函数
		},2000);
	}

这样就可以实现ajax的长轮询的效果。当然,这里只是使用reload进行获取,你也可以添加iframe和删除iframe的方式,进行发送信息,这些都是根据具体场景应用的。另外在iframe中还可以实现异步加载js文件,不过,iframe和主页是共享连接池的,所以还是很蛋疼的,现在基本上都被XHR和hardcalllback取缔了,这里也不过多介绍了。

转载请注明:码云笔记 » iframe的初步认识

喜欢 (2)or分享 (0)
发表我的评论
取消评论
表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址