源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
楼主: ttx9n

[HTML/Xhtml] iframe节点初始化的问题探讨

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2014-3-10 17:10:31 | 显示全部楼层 |阅读模式
本文为大家介绍下关于iframe节点初始化的问题:如果没有把iframe元素加入到DOM树中,iframe中的文档是不会初始化的 今天忽然想着复习一下富文本编辑器的制作原理。于是二话不说将手把手地做了起来。因为一年前写过一个简单的富文本编辑器,所以大概还是有点印象。可是当我把写出来的代码跑一下的时候,发现了问题:

复制代码代码如下:
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对象前:

复制代码代码如下:
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算是个异类吧。
回复

使用道具 举报

0

主题

2万

回帖

186

积分

注册会员

Rank: 2

积分
186
发表于 2023-6-23 23:59:09 | 显示全部楼层
儿飞飞微风DVD谁vdsvd
回复 支持 反对

使用道具 举报

3

主题

2万

回帖

301

积分

中级会员

Rank: 3Rank: 3

积分
301
发表于 2023-7-31 08:41:04 | 显示全部楼层
哟哟哟哟哟以偶
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2023-10-6 10:32:15 | 显示全部楼层
你们谁看了弄洒了可能
回复 支持 反对

使用道具 举报

2

主题

1万

回帖

146

积分

注册会员

Rank: 2

积分
146
发表于 2023-10-21 07:54:59 | 显示全部楼层
挺不错的东西
回复 支持 反对

使用道具 举报

4

主题

2万

回帖

262

积分

中级会员

Rank: 3Rank: 3

积分
262
发表于 2023-11-29 13:18:19 | 显示全部楼层
终于找到了,我擦
回复 支持 反对

使用道具 举报

2

主题

1万

回帖

146

积分

注册会员

Rank: 2

积分
146
发表于 2023-12-4 00:30:52 | 显示全部楼层
天天源码社区www.tiantianym.com
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2024-9-7 07:31:01 | 显示全部楼层
天天源码论坛
回复 支持 反对

使用道具 举报

6

主题

1万

回帖

174

积分

注册会员

Rank: 2

积分
174
发表于 2024-9-7 21:57:30 | 显示全部楼层
哈哈哈哈哈哈
回复 支持 反对

使用道具 举报

5

主题

2万

回帖

183

积分

注册会员

Rank: 2

积分
183
发表于 2024-9-16 10:40:56 | 显示全部楼层
女生看了弄丢了卡萨诺的卡洛斯
回复 支持 反对

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

GMT+8, 2024-11-23 21:04 , Processed in 0.073971 second(s), 24 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表