iframe的节点初始化


本文摘自PHP中文网,作者php中世界最好的语言,侵删。

这次给大家带来iframe的节点初始化iframe的节点初始化的注意事项有哪些,下面就是实战案例,一起来看一下。

今天忽然想着复习一下富文本编辑器的制作原理。于是二话不说将手把手地做了起来。因为一年前写过一个简单的富文本编辑器,所以大概还是有点印象。可是当我把写出来的代码跑一下的时候,发现了问题:

1

2

3

4

5

6

7

8

var ifr = document.createElement('iframe');

ifr.width = 300;

ifr.height = 300;

var idoc = ifr.contentDocument || ifr.contentWindow.document;

idoc.designMode = 'on';

idoc.contentEditable = true;

idoc.write('<html><head><style>body{ margin:0px; }</style></head><body></body></html>');

document.body.appendChild(ifr);

大家看看上面的代码,有没有发现哪里出现了批漏?
我想如果没有和我有类似经历的童鞋估计是看不出这段代码有什么问题的。那么大家不妨去跑一下,也许你很快就会发现问题。
下面由我来揭晓答案:
这段代码会抛找不到对象的异常。找不到哪个对象?找不到document对象,啥?怎么可能找不到document对象?当然,这个document对象是iframe的document对象。做过富文本的都知道要先获取了iframe的document对象才可以设置为可编辑。但是为什么我们获取不了document对象呢?这里我就不卖关子了。我说说我的解决流程吧。
首先我去谷歌了一下发现我获取document的写法是没有错的。然后我在想难道是Chrome的原因?难道Chrome抽风不支持这两个对象?于是换到了Firefox。结果还是一样。那么可以肯定的是,肯定是自己的代码问题。
后来通过对比网上的代码,发现自己的appendChild位置有点不对,于是乎就将它提前到了获取document对象前:

今天忽然想着复习一下富文本编辑器的制作原理。于是二话不说将手把手地做了起来。因为一年前写过一个简单的富文本编辑器,所以大概还是有点印象。可是当我把写出来的代码跑一下的时候,发现了问题:

1

2

3

4

5

6

7

8

var ifr = document.createElement('iframe');

ifr.width = 300;

ifr.height = 300;

var idoc = ifr.contentDocument || ifr.contentWindow.document;

idoc.designMode = 'on';

idoc.contentEditable = true;

idoc.write('<html><head><style>body{ margin:0px; }</style></head><body></body></html>');

document.body.appendChild(ifr);

大家看看上面的代码,有没有发现哪里出现了批漏?
我想如果没有和我有类似经历的童鞋估计是看不出这段代码有什么问题的。那么大家不妨去跑一下,也许你很快就会发现问题。
下面由我来揭晓答案:
这段代码会抛找不到对象的异常。找不到哪个对象?找不到document对象,啥?怎么可能找不到document对象?当然,这个document对象是iframe的document对象。做过富文本的都知道要先获取了iframe的document对象才可以设置为可编辑。但是为什么我们获取不了document对象呢?这里我就不卖关子了。我说说我的解决流程吧。
首先我去谷歌了一下发现我获取document的写法是没有错的。然后我在想难道是Chrome的原因?难道Chrome抽风不支持这两个对象?于是换到了Firefox。结果还是一样。那么可以肯定的是,肯定是自己的代码问题。
后来通过对比网上的代码,发现自己的appendChild位置有点不对,于是乎就将它提前到了获取document对象前:

1

2

3

4

5

6

7

8

var ifr = document.createElement('iframe');

ifr.width = 300;

ifr.height = 300;

document.body.appendChild(ifr);

var idoc = ifr.contentDocument || ifr.contentWindow.document;

idoc.designMode = 'on';

idoc.contentEditable = true;

idoc.write('<html><head><style>body{ margin:3px; word-wrap:break-word; word-break: break-all; }</style></head><body></body></html>');

结果运行一切顺利。然后我对此次的错误作了分析。其实这个错误的原理很简单。大家都知道iframe其实里面包含的是另一个文档,而这个文档只有初始化了才能拥有一个document对象。而如果没有把iframe元素加入到DOM树中,iframe中的文档是不会初始化的。因此,在一开始我们的代码里,我们获取的ifr变量中的contentDocument值是null,也就说明了此时iframe中的文档没有初始化。

顺着这条线,我再检查了别的节点的初始化情况,发现其实别的元素节点只要一旦创建,无论是否加入到DOM树中都会拥有其本身的属性和方法。也就是说在众多元素节点中iframe算是个异类吧。

结果运行一切顺利。然后我对此次的错误作了分析。其实这个错误的原理很简单。大家都知道iframe其实里面包含的是另一个文档,而这个文档只有初始化了才能拥有一个document对象。而如果没有把iframe元素加入到DOM树中,iframe中的文档是不会初始化的。因此,在一开始我们的代码里,我们获取的ifr变量中的contentDocument值是null,也就说明了此时iframe中的文档没有初始化。

顺着这条线,我再检查了别的节点的初始化情况,发现其实别的元素节点只要一旦创建,无论是否加入到DOM树中都会拥有其本身的属性和方法。也就是说在众多元素节点中iframe算是个异类吧。

相信看了这些案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

相关阅读:

html标准写法与dreamweaver生成代码有哪些不一样

如何使用iframe在当前网页中嵌入其他网页

在html里怎么添加flash视频格式(flv、swf)文件

谷歌浏览的label与input间距问题应该如何解决

HTML的头标签meta如何实现refresh重新定向

以上就是iframe的节点初始化的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

layui打开的layer的iframe窗口怎么关闭

教你在iframe标签中制作滚动条样式,iframe标签的用法介绍

iframe的跨域使用方法

iframe的各项参数

html阻止iframe跳转页面并使用iframe在页面内嵌微信网页版详解

使用iframe的一些小技巧

解决iframe嵌套页面无法全屏的问题

jquery如何获取iframe

iframe的子页面怎样操作父页屏蔽页面弹出层效果

如何使用html5地理位置定位功能?

更多相关阅读请进入《iframe》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...