document.write/writeln非IE/Opera浏览器中可能会造成元素获取不到
document.write/writeln在几年前的代码中见的比较多,多数情况下各浏览器表现一致。
1 2 3 4 5 6 7 8 9 10 11 | <!DOCTYPE html> <html> <head></head> <body> <script> document.write( '<div id="wraper"></div>' ); var obj = document.getElementById( 'wraper' ); alert(obj); </script> </body> </html> |
script标签写在body中,先write一个div,通过document.getElementById获取该元素。所有浏览器中都弹出了该div的信息框,证明这么写是支持的。
如果不小心把script写在head中呢,各个浏览器中行为将不一致,你可以测试下?
下面发现一个有趣的“Bug”
index.html
1 2 3 4 5 6 7 | <! DOCTYPE html> < html > < head ></ head > < body > < script src="a.js"></ script > </ body > </ html > |
a.js
1 2 3 | document.write( '<script src="b.js"></script>' ); document.write( '<div id="wraper">pp</div>' ) alert(document.getElementById( 'wraper' )); |
b.js
1 | // b.js中可以不写任何代码 |
index.html,在IE/Opera中会弹出信息框显示该div元素,其它浏览器均为null。
当然,罪魁祸首就是 document.write('<script src="b.js"></script>');
b.js中没写任何代码,但它的确影响了非IE/Opera浏览器,很难理解为何不显示div而是null。
如果把该句删除,所有浏览器都显示div。
猜测可能是是a.js中第一个document.write覆盖了后面的document.write。测试后发现也不对,其它不变,把a.js改为
1 2 3 | document.write( '<p>hello</p>' ); document.write( '<div id="wraper"></div>' ) alert(document.getElementById( 'wraper' )); |
这次write输出div[id=wraper]前也有一个write,但write的是p元素而非script元素,所有浏览器中表现一致都弹出div显示框而非null。
慎用document.write/writeln!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端