Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 393|回复: 0

[默认分类] js中document.write的那点事

[复制链接]
  • TA的每日心情
    开心
    2021-12-13 21:45
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2018-6-17 10:01:19 | 显示全部楼层 |阅读模式


          document.write()方法可以用在两个方面:页面载入过程中用实时脚本创建页面内容,以及用延时脚本创建本窗口或新窗口的内容。该方法需要一个字符串参数,它是写到窗口或框架中的HTML内容。这些字符串参数可以是变量或值为字符串的表达式,写入的内容常常包括HTML标记语言。
      

      
      记住,在载入页面后,浏览器输出流自动关闭。在此之后,任何一个对当前页面进行操作的document.write()方法将打开—个新的输出流,它将清除当前页面内容(包括源文档的任何变量或值)。因此,假如希望用脚本生成的HTML替换当前页面,就必须把HTML内容连接起来赋给一个变量,使用一个document.write()方法完成写操作。不必清除文档并打开一个新数据流,一个document.write()调用就可完成所有的操作。
      

      
      关于document.write()方法还有一点要说明的是它的相关方法document.close()。脚本向窗口(不管是本窗口或其他窗口)写完内容后,必须关闭输出流。在延时脚本的最后一个document.write()方法后面,必须确保含有document.close()方法,不这样做就不能显示图像和表单。并且,任何后面调用的document.write()方法只会把内容追加到页面后,而不会清除现有内容来写入新值。为了演示document.write()方法,我们提供了同一个应用程序的两个版本。一个向包含脚本的文档中写内容,另—个向—个单独的窗口写内容。请在文本编辑器中键人每个文档,以.html文件扩展名保存,并在浏览器中打开文档。
      

      
      示例1创建一个按钮,它为文档组合新的HTML内容,包括新文档标题的HTML标记和标记的颜色属性。示例中有一个读者所不熟悉的操作符+=,它把其右侧的字符串加到其左侧的变量中,这个变量用来存放字符串,这个操作符能很方便地把几个单独的语句组合成—个长字符串。使用组合在newContent变量中的内容,document.write()语句可以把所有新内容写到文档中,完全清除示例1中的内容。然后需要调用document.close()语句关闭输出流。当载入该文档并单击按钮时,可以注意到浏览器标题栏中的文档标题因此而改变。当回到原始文档并再次单击该按钮时,可以看到动态写入的第二个页面的载入速度甚至比重载原始文档还要快。
      

      

      示例1 在当前窗口使用document.write()。
      
      
    1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "[url=http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd]http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd[/url]">
    复制代码

    1. <html xmlns="[url=http://www.w3.org/1999/xhtml&quot;>]http://www.w3.org/1999/xhtml">[/url]<title>Writing to Same Doc</title>
    2. <script language="JavaScript">
    3.   function reWrite(){
    4.     // assemble content for new window
    5.     var newContent = "<html><head><title>A New Doc</title></head>"
    6.     newContent += "<body bgcolor="aqua"><h1>This document is brand new.</h1>"
    7.     newContent += "Click the Back button to see original document."
    8.     newContent += "</body></html>"
    9.     // write HTML to new window document
    10.     document.write(newContent)
    11.     document.close() // close layout stream
    12.   }
    13. </script>
    14. </head>
    15. <body>
    16.   <form>
    17.     <input type="button" value="Replace Content" onClick="reWrite()">
    18.   </form>
    19. </body>
    20. </html>
    复制代码

      

        示例2中,情况有点复杂,因为脚本创建了一个子窗口,整个脚本生成的文档都将写入该窗口中。为了使新窗口的引用在两个函数中保持激活状态,我们将newWindow变量声明为全局变量。页面载入时,onLoad事件处理调用makeNewWindow()函数,该函数生成一个空的子窗口。另外,我们在window.open()方法的第三个参数中加入一个属性,使子窗口的状态栏可见。

      页面上的按钮调用subWrite()方法,它执行的第一个任务是检查子窗口的closed属性。假如关闭了引用窗口,该属性(只在较新的浏览器版本中存在)返回true。如果是这种情况(假如用户手动关闭窗口),该函数再次调用makeNewWindow()函数来重新打开那个窗口。

      窗口打开后,新的内容作为字符串变量组合在一起。与示例1一样,一次性写入内容(虽然对单独的窗口没有必要),接下来调用close()方法。但是注意一个重要的区别:write() 和 close()方法都明显地指定了子窗口。

      

      示例2 在另一个窗口中使用document.write()
      

    1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "[url=http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd]http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd[/url]">
    复制代码

    1. <html xmlns="[url=http://www.w3.org/1999/xhtml&quot;>]http://www.w3.org/1999/xhtml">[/url]<title>Writing to Subwindow</title>
    2. <script language="JavaScript">
    3.   var newWindow
    4.   function makeNewWindow(){
    5.     newWindow = window.open("","","status,height=200,width=300")
    6.   }
    7.   function subWrite(){
    8.     // make new window if someone has closed it
    9.     if(newWindow.closed){
    10.       makeNewWindow()
    11.     }
    12.     // bring subwindow to front
    13.     newWindow.focus()
    14.     // assemble content for new window
    15.     var newContent = "<html><head><title>A New Doc</title></head>"
    16.     newContent += "<body bgcolor="coral"><h1>This document is brand new.</h1>"
    17.     newContent += "</body></html>"
    18.     // write HTML to new window document
    19.     newWindow.document.write(newContent)
    20.     newWindow.document.close()    // close layout stream
    21.   }
    22. </script>
    23. </head>
    24. <body onLoad="makeNewWindow()">
    25.   <form>
    26.     <input type="button" value="Write to Subwindow" onClick="subWrite()">
    27.   </form>
    28. </body>
    29. </html>
    复制代码

      
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-4-24 15:47 , Processed in 0.415450 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

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