历数Firefox2.0对XML处理的改进

作者:袖梨 2022-07-02

Firefox 2.0 在对 XML 的支持方面有几个重要的改进。目前它的用户部署如日中天。了解 Firefox 2.0 XML 特性的改进,包括在 RSS Web 提要处理方面有争议的变化。

被赋予新应用程序平台的角色后,现在 Web 浏览器可能是最热门的软件。对于软件开发人员来说这是令人激动的时刻,动态 HTML 技术以 Asynchronous JavaScript + XML (Ajax) 获得重生,Microsoft® Internet Explorer® 的开发得以恢复等等。过去两年中,关于 XML 和 Firefox 的 developerWorks 系列文章(请参阅 参考资料)介绍了以 1.8 版本的核心 Mozilla 浏览器引擎为基础的 Firefox 1.5 版。此后,Mozilla 项目永不停歇的开发步伐又催生了 Firefox 2.0,它以 Gecko 1.8.1 Web 呈现引擎为基础。Firefox 2.0 的一些改进涉及到 XML 处理。本文介绍了最新的 Firefox XML 处理功能,包括开发人员应该记住的可能遇到的主要障碍。


减少了对 Web 提要的控制

Firefox 2.0 一个变化引起了用户社区的极大惊慌。如果提供 RSS 或 Atom 这类 Web 提要,可能需要包括 XSLT 样式表为用户转换成其他表示形式。清单 1 中的 Atom 提要引用了这样的转换。

 

清单 1. 包含样式表引用的 Atom 提要



http://www.w3.org/2005/Atom"
 xml:lang="en"
 xml:base="http://www.example.org">
 http://www.example.org/myfeed
 My Simple Feed
 2005-07-15T12:00:00Z
 
 
 Uche Ogbuji
 
 http://www.example.org/entries/1
 A simple blog entry
 
 2005-07-14T12:00:00Z


 

This is a simple blog entry
 
 
 http://www.example.org/entries/2
 <br />  <link href="/blog/2005/07/2" /><br />  <updated>2005-07-15T12:00:00Z</updated><br />  <summary>This is simple blog entry without a title</summary><br />  </entry><br /> </feed><br />  </p> <p>关键是第二行中的样式表处理指令(PI)。如果用 Firefox 1.5 打开,浏览器就会尽职尽责地加载 atom2html.xslt 并显示结果。本系列文章第 2 部分(请参阅 参考资料)已经提到,查看实际的 XML 必须通过 “查看源代码”。在 Firefox 2.0 中,浏览器忽略该样式表 PI 并使用定制的 Firefox 视图查看,如图 1 所示(Firefox 2.0.0.6、Mac OS X 平台上的屏幕截图)。</p> <p> </p> <p>图 1. Firefox 2.0 内置的 Web 提要视图</p> <p><br />  避免这种情况并强制使用所选样式表,惟一的办法就是愚弄头脑简单的 Firefox,它通过在文件前 512 个字节中查找 “rss” 或 “feed” 来判定是否为 Web 提要。清单 2 采用了一种广为人知的办法,专门插入一段注释来填充这 512 个字节。</p> <p> </p> <p>清单 2. 绕过 Firefox 2.0 和 Internet Explorer 7 默认样式表处理方式的 Atom 提要</p> <p><br /> <?xml version="1.0" encoding="utf-8"?><br /> <!-- Firefox 2.0 and Internet Explorer 7 use simplistic feed sniffing to override desired<br /> presentation behavior for this feed, and thus we are obliged to insert this comment, a<br /> bit of a waste of bandwidth, unfortunately. This should ensure that the following<br /> stylesheet processing instruction is honored by these new browser versions. For some more<br /> background you might want to visit the following bug report:<br /> <a href="https://bugzilla.mozilla.org/show_bug.cgi?id=338621">https://bugzilla.mozilla.org/show_bug.cgi?id=338621</a><br /> --><br /> <?xml-stylesheet type="text/xml" href="atom2html.xslt"?><br /> <feed xmlns="<a href="http://www.w3.org/2005/Atom">http://www.w3.org/2005/Atom</a>"<br />  xml:lang="en"<br />  xml:base="<a href="http://www.example.org">http://www.example.org</a>"><br /> <!-- content of the feed identical to listing 1, so trimmed --></p> <p> </p> <p></feed><br />  </p> <p>考虑了用户社区的反对意见之后,Firefox 开发人员决定坚持自身的立场,因而这种行为方式将保留到未来的 Firefox 版本之中。我个人不喜欢这种方式,您可以阅读有关的争论再决定喜欢与否。值得一提的是,这种做法与 Internet Explorer 和 Apple Safari 有相似之处。</p> <p> </p> </div> </div> </section> <section class="wrap-box"> <div class="g-tit"> <h2>相关文章</h2> </div> <ul class="s-list nobord notop"> <li> <a href="/art-451007.htm" class="s-card"> <div class="s-card-l"> <p class="tit">原神丝柯克技能介绍一览</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-07-25</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250725/logo_68830002035c71.jpg" alt="原神丝柯克技能介绍一览" /> </div> </a> </li> <li> <a href="/art-450823.htm" class="s-card"> <div class="s-card-l"> <p class="tit">Uniswap怎么部署合约-uniswap 部署</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-07-25</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250725/logo_6882e636d7c421.jpg" alt="Uniswap怎么部署合约-uniswap 部署" /> </div> </a> </li> <li> <a href="/art-451008.htm" class="s-card"> <div class="s-card-l"> <p class="tit">失控进化坦克怎么打 坦克打法攻略</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-07-25</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250725/logo_688300028e7681.png" alt="失控进化坦克怎么打 坦克打法攻略" /> </div> </a> </li> <li> <a href="/art-451009.htm" class="s-card"> <div class="s-card-l"> <p class="tit">金铲铲之战s14迅射鳄鱼阵容玩法教学</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-07-25</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250725/logo_688300034aec51.png" alt="金铲铲之战s14迅射鳄鱼阵容玩法教学" /> </div> </a> </li> <li> <a href="/art-451010.htm" class="s-card"> <div class="s-card-l"> <p class="tit">炉石传说阿莎曼贼卡组怎么玩 阿莎曼贼卡组玩法教学</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-07-25</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250725/logo_68830004ae5bc1.png" alt="炉石传说阿莎曼贼卡组怎么玩 阿莎曼贼卡组玩法教学" /> </div> </a> </li> <li> <a href="/art-450824.htm" class="s-card"> <div class="s-card-l"> <p class="tit">鱼池怎么增加矿工-鱼池怎么增加矿工量</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-07-25</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250725/logo_6882e6378d3ff1.jpg" alt="鱼池怎么增加矿工-鱼池怎么增加矿工量" /> </div> </a> </li> </ul> </section> <section class="wrap-box"> <div class="g-tit"> <h2>精彩推荐</h2> </div> <ul class="card-box"> <li class="card3"> <a href="/app/127576.htm" target="_self" class="figure"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250725/logo_68832bfe58bde1.jpg" alt="溜冰者战斗" /> </div> <p class="figure-head">溜冰者战斗</p> <span class="figure-btn">下载</span> </a> </li> <li class="card3"> <a href="/app/127578.htm" target="_self" class="figure"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250725/logo_68832c00f34e31.jpg" alt="战斗芭蕾" /> </div> <p class="figure-head">战斗芭蕾</p> <span class="figure-btn">下载</span> </a> </li> <li class="card3"> <a href="/app/127579.htm" target="_self" class="figure"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250725/logo_68832c030b4a31.jpg" alt="动感光剑" /> </div> <p class="figure-head">动感光剑</p> <span class="figure-btn">下载</span> </a> </li> <li class="card3"> <a href="/app/127586.htm" target="_self" class="figure"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250725/logo_68832c07ecf1d1.jpg" alt="领域战争" /> </div> <p class="figure-head">领域战争</p> <span class="figure-btn">下载</span> </a> </li> </ul> <ul class="card-box-b"> <li class="card10"> <a href="/app/127149.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250724/logo_6881da94ae2691.png" alt="沙盒多元宇宙" /> </div> <div class="figure-cont"> <p class="figure-head">沙盒多元宇宙</p> <div class="figure-desc"> <span>模拟经营</span> <span>沙盒多元宇宙</span> </div> <div class="figure-desc"> <p>沙盒多元宇宙让你尽情发挥创造力,搭建属于自己的梦幻世界。这里</p> </div> </div> <span class="figure-btn">下载</span> </a> </li> <li class="card10"> <a href="/app/127159.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250724/logo_6881daa04ec351.png" alt="蛋糕工坊物语" /> </div> <div class="figure-cont"> <p class="figure-head">蛋糕工坊物语</p> <div class="figure-desc"> <span>模拟经营</span> <span>蛋糕工坊物语</span> </div> <div class="figure-desc"> <p>蛋糕工坊物语带你进入甜蜜的烘焙世界,从混合食材到装饰蛋糕,每</p> </div> </div> <span class="figure-btn">下载</span> </a> </li> <li class="card10"> <a href="/app/123952.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250716/logo_68770867663fc1.png" alt="宇宙沙盘" /> </div> <div class="figure-cont"> <p class="figure-head">宇宙沙盘</p> <div class="figure-desc"> <span>模拟经营</span> <span>宇宙沙盘</span> </div> <div class="figure-desc"> <p>宇宙沙盘充满无限想象与创造自由,玩家可任意飞行,在像素世界中</p> </div> </div> <span class="figure-btn">下载</span> </a> </li> <li class="card10"> <a href="/app/111483.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250606/logo_6842457fa9a081.png" alt="糖果气泡安卓版" /> </div> <div class="figure-cont"> <p class="figure-head">糖果气泡安卓版</p> <div class="figure-desc"> <span>模拟经营</span> <span>糖果气泡安卓版</span> </div> <div class="figure-desc"> <p>糖果气泡安卓版带来经典的泡泡消除体验,玩法简单却充满挑战。游</p> </div> </div> <span class="figure-btn">下载</span> </a> </li> <li class="card10"> <a href="/app/120951.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250708/logo_686ca753b8f631.png" alt="海洋幸存者" /> </div> <div class="figure-cont"> <p class="figure-head">海洋幸存者</p> <div class="figure-desc"> <span>模拟经营</span> <span>海洋幸存者</span> </div> <div class="figure-desc"> <p>海洋幸存者带你进入波涛汹涌的蓝色世界,一切从一块木筏开始。你</p> </div> </div> <span class="figure-btn">下载</span> </a> </li> </ul> </section> <footer class="foot"> <a href="/" class="logo-icon"> <img src="/mobile/images/logo2.png" alt="一聚教程网"> </a> <p>Copyright © 2010-2022</p> <p>111cn.net All Rights Reserved</p> </footer> <script> var advData = {"img_fixed_pc_adv":"https:\/\/img.111cn.net\/uploads\/20240509\/663c2e9729f58.jpg","img_fixed_mob_adv":"https:\/\/img.111cn.net\/uploads\/20240509\/663c2e8793225.jpg","url_adv":"http:\/\/shop.hushen.cn\/shop\/c\/baojianpin.html","str_adv":"\u864e\u795e\u5546\u57ce\uff1a\u5173\u7231\u7537\u6027\uff0c\u66f4\u61c2\u7537\u4eba\u3002\u89e3\u51b3\u5927\u4f17\u7684\u7537\u8a00\u4e4b\u9690","img_popup_adv":"https:\/\/img.111cn.net\/uploads\/20240509\/663c2e748238d.png","pc_show_img":"2","pc_show_popup":"2","pc_show_video":"2","mob_show_img":"2","mob_show_popup":"2","mob_show_video":"2","close_adv":"https:\/\/img.111cn.net\/uploads\/20240508\/663b20650801e.png","video_adv":"\/pc\/images\/pc-adv.mp4"}; </script> <script src="/jspc/funcmob.js" type="text/javascript"></script> <!-- Google tag (gtag.js) --> <script async src="https://www.googletagmanager.com/gtag/js?id=G-DSRRGRV1TL"></script> <script> window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', 'G-DSRRGRV1TL'); </script> <div class="back-top" style="display: block;"> <span class="icon-box"> <svg class="icon" viewBox="0 0 1024 1024"> <path d="M213.333333 640h170.666667v256h256v-256h170.666667l-298.666667-341.333333zM170.666667 128h682.666666v85.333333H170.666667z" fill="#0374f3"></path> </svg> </span> </div> </div> <script src="/js/stat.js"></script> </body> </html>