iframe的节点初始化

这次给大家带来iframe节点初始化,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('body{ margin:0px; }'); 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; var idoc = ifr.contentDocument || ifr.contentWindow.document; idoc.designMode = 'on'; idoc.contentEditable = true; idoc.write('body{ margin:0px; }'); 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('body{ margin:3px; word-wrap:break-word; word-break: break-all; }');

登录后复制

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

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

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

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

相信看了这些案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

相关阅读:

注意事项

注意事项

注意事项

注意事项

注意事项

以上就是iframe的节点初始化的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3087066.html

(0)
上一篇 2025年3月28日 07:47:50
下一篇 2025年3月2日 18:41:11

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • iframe的去边框和无边框有哪些操作方式

    这次给大家带来iframe的去边框和无边框有哪些操作方式,iframe去边框和无边框的操作方式的注意事项有哪些,下面就是实战案例,一起来看一下。 登录后复制登录后复制登录后复制 登录后复制登录后复制登录后复制 runat=”se…

    编程技术 2025年3月28日
    100
  • iframe的各项参数

    这次给大家带来iframe的各项参数,iframe各项参数的注意事项有哪些,下面就是实战案例,一起来看一下。 iframe src=”test.jsp” width=”100″ height=”50″ frameborder=”no” bo…

    编程技术 2025年3月28日
    100
  • iframe的跨域使用方法

    这次给大家带来iframe的跨域使用方法,我们知道,在前端界面中我们时常会用到iframe这个标签,那么iframe跨域使用的注意事项有哪些,下面就是实战案例,一起来看一下。 同一个 origin 下:父页面可以通过 iframe.cont…

    编程技术 2025年3月28日
    100
  • vue.js怎么删除dom节点

    vue.js删除dom节点的方法:1、v-for循环dom节点,保证每个li都有一个删除按钮,并绑定删除事件;2、删除dom节点,如【this.datahistory.splice(this.$refs.li[index], 1)】。 本文…

    2025年3月13日
    200
  • 如何通过Vue和jsmind实现思维导图的节点复制和剪切功能?

    如何通过Vue和jsmind实现思维导图的节点复制和剪切功能? 思维导图是一种常见的思维工具,能够帮助我们整理思路、梳理思维逻辑。而节点复制和剪切功能是思维导图中常用的操作,能让我们更方便地重复利用已有的节点,提高思维整理的效率。 在本文中…

    2025年3月13日
    200
  • layui打开的layer的iframe窗口怎么关闭

    (1)关闭特定iframe //当在iframe页面关闭自身时,在iframe页执行以下js脚本var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引pa…

    2025年3月13日
    200
  • html中scrolling是什么意思

    在html中,scrolling的中文意思为“滚动”;它是iframe标签的一个属性,用于规定是否在iframe中显示滚动条,语法格式“”,可设置的属性值有auto、yes、no。 本教程操作环境:windows7系统、HTML5版、Del…

    2025年3月11日
    200
  • html5中节点是什么意思

    在html5中,节点(node)是构成网页的最基本的组成部分,网页中的每一个部分都可以称为是一个节点;如: html 元素、属性、文本、注释、整个文档等都是一个节点。 本教程操作环境:windows7系统、HTML5版、Dell G3电脑。…

    2025年3月11日
    200
  • es6声明变量必须初始化吗

    es6声明变量不是必须初始化的。在es6中,利用关键字var和let声明的变量是可以修改的,因此可以不初始化,此时变量会被系统默认赋予一个初始值“undefined”;而利用关键字const声明的变量不可以修改,是必须初始化的,否则会报错。…

    2025年3月11日
    200
  • react怎么给树增加节点

    react给树增加节点的方法:1、引入antd的树形控件,并通过“const treeData = […]”实现tree形组件;2、把当前节点的key值传递过去,然后遍历data数组;3、在遍历数组增加节点时,通过嵌套数组对象的…

    2025年3月11日
    200

发表回复

登录后才能评论