历数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-458704.htm" class="s-card"> <div class="s-card-l"> <p class="tit">下一站江湖2守卫藏经阁具体位置</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-08-21</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250821/logo_68a6e18b8d8301.png" alt="下一站江湖2守卫藏经阁具体位置" /> </div> </a> </li> <li> <a href="/art-458705.htm" class="s-card"> <div class="s-card-l"> <p class="tit">无畏契约手游自选英雄选择推荐</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-08-21</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250821/logo_68a6e18c0f9001.png" alt="无畏契约手游自选英雄选择推荐" /> </div> </a> </li> <li> <a href="/art-458706.htm" class="s-card"> <div class="s-card-l"> <p class="tit">原神谛踪匿行后日谈派蒙具体位置</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-08-21</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250821/logo_68a6e18c8a7791.jpg" alt="原神谛踪匿行后日谈派蒙具体位置" /> </div> </a> </li> <li> <a href="/art-458707.htm" class="s-card"> <div class="s-card-l"> <p class="tit">心动小镇泡泡位置在哪-5.17-5.23泡泡位置攻略</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-08-21</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250821/logo_68a6e209eda711.jpg" alt="心动小镇泡泡位置在哪-5.17-5.23泡泡位置攻略" /> </div> </a> </li> <li> <a href="/art-458708.htm" class="s-card"> <div class="s-card-l"> <p class="tit">心动小镇稚趣园限定食谱有哪些-稚趣园限定食谱获取攻略</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-08-21</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250821/logo_68a6e20a8a20b1.jpg" alt="心动小镇稚趣园限定食谱有哪些-稚趣园限定食谱获取攻略" /> </div> </a> </li> <li> <a href="/art-458709.htm" class="s-card"> <div class="s-card-l"> <p class="tit">不良人破局李星云玉佩选什么好-李星云配装推荐</p> <div class="info"> <span class="person">游戏攻略</span> <span class="time">2025-08-21</span> </div> </div> <div class="s-card-pic"> <img src="/images/lazy.gif" data-src="/uploads/20250821/logo_68a6e20b2a1511.png" 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/135804.htm" target="_self" class="figure"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250821/logo_68a672d9d51021.png" alt="猿神启动" /> </div> <p class="figure-head">猿神启动</p> <span class="figure-btn">下载</span> </a> </li> <li class="card3"> <a href="/app/135806.htm" target="_self" class="figure"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250821/logo_68a672dd417bd1.jpg" alt="木工生存岛" /> </div> <p class="figure-head">木工生存岛</p> <span class="figure-btn">下载</span> </a> </li> <li class="card3"> <a href="/app/135814.htm" target="_self" class="figure"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250821/logo_68a672ea4cff81.jpg" alt="原始小人族" /> </div> <p class="figure-head">原始小人族</p> <span class="figure-btn">下载</span> </a> </li> <li class="card3"> <a href="/app/127713.htm" target="_self" class="figure"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250728/logo_6886cdfc361f01.png" 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/123192.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250714/logo_68745ac9699851.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/135802.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250821/logo_68a672d69f3c91.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/135805.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250821/logo_68a672db917181.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/135807.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250821/logo_68a672dea34af1.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/135815.htm" target="_self" class="figure2"> <div class="figure-box"> <img src="/images/lazy.gif" data-src="https://img.111cn.net/uploads/20250821/logo_68a672ec3b28b1.jpg" 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>