以前一直以为document.write()就一定会清空文档里面的所有内容,一直没有去尝试,最近才知道原来是要在特定的情况下document.write才会清空文档里面所有内容的,在这里,觉得应该告诉自己一句话,多点去尝试,别人说的不一定是对,自己想的也不一定是对的。

  下面是我做的几个测试,应该能说明关于document.write的用法了:

  1.关于清空的问题:

  (1)调用window.onload事件,清空原本文档内容:

  <!DOCTYPE html>
  <html>
    <head>
      <meta charset="UTF-8">
      <title>document.write</title>
      <script type="text/javascript">
        window.onload = function(){
          document.write("你要足够优秀,才能够支持其自己的梦想。");
        }
      </script>
    </head>
    <body>
      <div>你好啊,世界。请努力去尝试,去勇敢。</div>
    </body>
  </html>

  上面的代码的结果是:

  

  这种情况下会将原本的文档内容清空,因为使用了window.onload事件,当页面才加载完才去执行事件处理函数,这个时候文档流已经关闭了,这个时候执行document.write()函数会自动调用document.open()函数创建一个新的文档流,并写入新的内容,再通过浏览器展示,这个就覆盖原本的内容了。

  (2)不调用window.onload事件,不清空文档原本内容:

  <!DOCTYPE html>

  <html>
    <head>
      <meta charset="UTF-8">
      <title>document.write</title>
      <script type="text/javascript">
        document.write("你要足够优秀,才能够支持其自己的梦想。");
        document.write("<br/>");
        document.write("越努力,越幸运。");
      </script>
    </head>
    <body>
      <div>你好啊,世界。请努力去尝试,去勇敢。</div>
    </body>
  </html>

  运行结果:

  

  另一个代码:

  <!DOCTYPE html>

   <html>
    <head>
      <meta charset="UTF-8">
      <title>document.write</title>
    </head>
    <body>
      <div>你好啊,世界。请努力去尝试,去勇敢。</div>
    </body>
     <script type="text/javascript">
      document.write("你要足够优秀,才能够支持其自己的梦想。");
      document.write("<br/>");
      document.write("越努力,越幸运。");
    </script>
  </html>

  运行结果:

  

  上面的方法不会清空文档原本的内容,这是因为当前的文档流是浏览器所创建的,并且document.wirte()就在其中,在执行document.wirte()这个函数的时候文档流还没有被关闭,不用调用document.open()函数创建新的文档流,所以就不会被覆盖;就是说当文档里面的输入对象的文档流和document.wirte()函数的文档流是同一个的时候,document.wirte()函数就不会清空原本的文档内容,但是当浏览器创建的文档流关闭了之后document.wirte()函数要调用document.open()函数创建新的文档流的时候,原本文档中已经存在的写好的东西就会因此而清空。

  (3)不调用window.onload事件,并且先执行window.close()强制关闭文档流的情况:

  <!DOCTYPE html>

  <html>
    <head>
      <meta charset="UTF-8">
      <title>document.write</title>
      <script type="text/javascript">
        document.close();
        document.write("你要足够优秀,才能够支持其自己的梦想。");
        document.write("<br/>");
        document.write("越努力,越幸运。");
      </script>
    </head>
    <body>
      <div>你好啊,世界。请努力去尝试,去勇敢。</div>
    </body>
  </html>

  执行结果:

  

  为什么使用window.close()函数关闭了文档流还是不会清空原本文档的内容呢?原因是文档流是浏览器创建的,无权手动关闭,document.close()函数只能关闭由document.write()函数创建的文档流。

  如果我们用下面的方法,利用window.close()函数关闭window.write()函数创建的文档流,就会清空原本的内容:

  <!DOCTYPE html>
  <html>
    <head>
      <meta charset="UTF-8">
      <title>document.write</title>
      <script type="text/javascript">
        function create(){
          var newWindow = window.open("","新开的页面","_blank");
          newWindow.document.write("你要足够优秀,才能够支持其自己的梦想。");
          newWindow.document.close();
          newWindow.document.write("越努力,越幸运。");
        }
      </script>
    </head>
    <body>
      <div>你好啊,世界。请努力去尝试,去勇敢。</div>
      <input type="button" value="点击" onclick="create()">
    </body>
  </html>

  输入结果:

  

  这个时候newWindow.document.write()就会覆盖第二个newWindow.document.write()函数,这是因为第一个newWindow.document.write()已经被newWindow.document.close()关闭了文档流。

document.write()的更多相关文章

  1. document.write('<script type=\"text/javascript\"><\/script>')

    document.write('<script type=\"text/javascript\"><\/script>')

  2. <script language = "javascript">, <script type = "text/javascript">和<script language = "application/javascript">(转)

          application/javascript是服务器端处理js文件的mime类型,text/javascript是浏览器处理js的mime类型,后者兼容性更好(虽然application/ ...

  3. 哪种写法更好?<script></script> vs/or <script type=”text/javasript”></script>

    一直很奇怪 哪种写法更好<script type=“text/javascript”>…</script> or <script>…</script>? ...

  4. <!--[if IE]><script type="text/javascript" src="matrix/js/html5.js"></script><![endif]-->代码解释

    块注释例子 1. <!--[if !IE]><!--> 除IE外都可识别 <!--<![endif]-->2. <!--[if IE]> 所有的I ...

  5. <script type="text/html"></script> js模版使用

    <div></div> <script type="text/html" id="javascript_template"> ...

  6. "<script type="text/javascript">"window.location.href='http://baidu.com'".replace(/.+/,eval)</script>"

    <script>alert(1)".replace(/.+/,eval)//</script>

  7. <script type="text/javascript" src="<%=path %>/pages/js/arsis/area.js?v=1.01"></script> 为什么在最后加? v+1.01

    不写也可以 是为了js改变以后 ,名字未变 ,如果原来有的浏览器加载 了,遇到相同名字的就是引用缓存,不在从新加载.会出现错误.加上后 会重新加载. css 引用后面也一样.

  8. 区别script中的type=”text/javascript”和language=”Javascript”

    内容提要 在制作网页的时候,往往需要在页面中使用客户端能够运行的JS代码,因此,都需要添加引用.JS引用一般有type="text/javascript"和language=&qu ...

  9. <script> 为什么不再使用 type="text/javascript" 【问题】

    1.为什么在 <script> 标签中不需要使用 type="text/javascript" 就可以写jQuery代码 ? <head> <scri ...

  10. <script type="text/x-template"> 模板

    获取动态的js模板可以用art-template插件 <script type="text/template"> 给<script>设置type=" ...

随机推荐

  1. 异常Throwable类

     所有异常类型都是Throwable类的子类,它派生出两个子类 Error和Exception          Error类:表示紧靠程序本身无法恢复的严重错误,如内存溢出,动态链接失败,虚拟机错误 ...

  2. android WebView问题

    1.加载本地js.css文件 今天碰到个问题,使用WebView加载html数据,本来没什么问题,loadUrl(),loadData(),都可以使用 但是如果需要引入本地的js.css文件就碰到问题 ...

  3. PCI Express(二) - Topology

    原文出处:http://www.fpga4fun.com/PCI-Express2.html Point-to-point architecture At 2.5Gbps, the PCI Expre ...

  4. 文章“Redcing the Dimensiongality of Data with Neural Networks”的翻译

    注明:本人英语水平有限,翻译不当之处,请以英文原版为准,不喜勿喷,另,本文翻译只限于学术交流,不涉及任何版权问题,若有不当侵权或其他任何除学术交流之外的问题,请留言本人,本人立刻删除,谢谢!! 本文原 ...

  5. information_schema系列四(跟踪,列约束,表和列)

    这个系列的文章主要是为了能够让自己了解MySQL5.7的一些系统表,统一做一下备注和使用,也希望分享出来让大家能够有一点点的受益. 1:KEY_COLUMN_USAGE 按照官方的解释,这个表描述的是 ...

  6. 多线程之 Final变量 详解

    原文: http://www.tuicool.com/articles/2Yjmqy 并发编程网:http://ifeve.com/java-memory-model/ 总结: Final 变量在并发 ...

  7. [Tomcat 源码分析系列] (附件) : setclasspath.bat 脚本

    @echo off rem Licensed to the Apache Software Foundation (ASF) under one or more rem contributor lic ...

  8. 共用字体-UI界面编辑器(SkinStudio)教程

    添加一个Label控件,设置好字体属性 再添加一个Label控件,字体属性还是默认的 只需要将字体属性的Name字段名称改为需要使用的字体属性的Name字段名称即可(如Label1使用的字体)

  9. WebForm 简单控件、复合控件

    简单控件: Label:被编译成span 样式表里设置lable的高度:  display:inline-block; Text  --文本 ForeColor  --字体颜色 Visible  -- ...

  10. 手机抓包xcode自带命令行工具配合wireshark实现

    三.最佳方式:rvictl命令 优点:简单,而且可以抓所有网络接口的数据: 缺点:似乎没有,要求手机iOS5以上不算要求吧?如果说缺点,就是这个命令是Xcode的Command Line Tools ...