never-online 's Tech Blog In CSDN

never online - Everlasting love for angela.

用户操作
[即时聊天] [发私信] [加为好友]
never-onlineID:BlueDestiny
154014次访问,排名502好友17人,关注者33
在京城
BlueDestiny的文章
原创 114 篇
翻译 0 篇
转载 8 篇
评论 224 篇
never-online的公告
Web:
www.never-online.net
Email:
BlueDestiny##126.com
QQ:
77091373
最近评论
kwlong2008:来看看朋友,最近过的怎么样?俺的空间是介绍网站制作网站建设的,有时间也常去一下我的空间谢谢,wow gold

When you play a game of the day, the list of friends in the game whether there are always a few names of black
wow power leveling<……
zyhomepage:支持一下
clicksun:如果要制作纯CSS+DIV的圆角方框图形,可以到这里直接在线制作,什么颜色都可以:http://corner.cha.la
C_SuperMe:可以好好学习一下啊!!
文章分类
收藏
相册
icon
JS & DHTML
Dhteumeuleu
Douglas Crockford
Webfx
常去之地
ASP.Net
MSDN英文
XML指南
XML的大本营
博客园
正则表达式
我的网站
我网站的Blog(RSS)
友情链接
KimSoft的blog(RSS)
存档
软件项目交易
订阅我的博客
XML聚合  FeedSky
订阅到鲜果
订阅到Google
订阅到抓虾
订阅到BlogLines
订阅到Yahoo
订阅到GouGou
订阅到飞鸽
订阅到Rojo
订阅到newsgator
订阅到netvibes

原创 [HOW TO] 如何在Mozilla Gecko 用Javascript加载XSL收藏

新一篇: 如何让动态插入的javascript脚本代码跑起来。 | 旧一篇: 用XHTML CSS做漂亮的阴影菜单

 

先看效果。 Click Here To View 

在Mozilla Develop Center里,我们可以看到有以下的文章:http://developer.mozilla.org/en/docs/The_XSLT/JavaScript_Interface_in_Gecko:Basic_Example
首先,你需要了解如何动态载入xml文件的方法,可以用XMLDOM对象,也可以用XMLHttpRequest,的responseXML对象,这里我用的是XMLHttpRequest。

用javascript载入xslt的方法如下:
1。用XMLDOM或者用XMLHttpRequest来加载xml和xslt。
2。用XSLTProcessor.importStylesheet来引入XSLT。
3。用XSLTProcessor.transformToFragment方法来把它转换成DOM的Fragment。然后用appendChild或者用insertBefore等方法来追加或者插入这个DOM的fragment元素。
示例代码

var ownerDocument = document.implementation.createDocument("", "test", null);
var newFragment = processor.transformToFragment(domToBeTransformed, ownerDocument);

当然也可以用transformToDocument
var newDocument = processor.transformToDocument(domToBeTransformed);
需要注意的是,转换后的节点是Element或者是一个片段,所以要经过下面的序列化才可使用obj.innerHTML=new Document
4。序列化。

(new XMLSerializer()).serializeToString(newDocument)

5。在IE中,可以用XMLDOM方法,xmldoc.transformNode(xslDocument)方法来进行接的转换。

首先,我们先建立一个XML文件与XSLT文件,方便后面的讲解。
foo.xml

<?xml version="1.0" encoding="utf-8"?>
<Article>
<Title>javascript load xslt in ie and mozilla</Title>
<Author>never-online</Author>
  
<Web>http://www.never-online.net</Web>
<Body>content is here</Body>
</Article>

foo.xsl

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html" />
<xsl:template match="/">
<h1 class="title"><xsl:value-of select="/Article/Title"/></h1>
<div class="desc">Author: <xsl:value-of select="/Article/Author"/> - 
Web: 
<xsl:value-of select="/Article/Web"/></div>
<class="box">
<xsl:value-of select="/Article/Body"/>
</p>
</xsl:template>
</xsl:stylesheet>
 
foo.html
 
<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/tr/html4/strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
 
<title> convert xsl using javascript - http://www.never-online.net </title>
 
<meta http-equiv="ImageToolbar" content="no" />
 
<meta name="author" content="never-online, BlueDestiny"/>
 
<meta name="keywords" content="never modules, Mozilla CSS, C#, .net, Refercence, BlueDestiny, never-online"/>
 
<meta name="description" content="BlueDestiny, never-online"/>
 
<meta name="title" content=" - http://www.never-online.net" />
 
<meta name="creator.name" content="never-online, BlueDestiny" />
 
<style type="text/css" media="all" title="Default">
.title 
{ margin:10px 10% 0 10%; text-align:center; background-color:#639ACE; padding:10px; color:#fff; }
.desc 
{ margin:10px 10% 0 10%; text-align:center; }
.box 
{ margin:10px 10% 0 10%; border: 1px dotted #639ACE; padding:20px; }
 
</style>
 
<script type="text/javascript">
 
//<![CDATA[

 
//]]>
 
</script>
 
<body id="www.never-online.net">
<div id="demo"></div>
<script type="text/javascript">
//<![CDATA[
 var xsltParser = function(xmlfileStr, xslfileStr) {
 
var retval = xslStylesheet = xmlDocument = null;
 
var browser = 
 isIE:
!!window.ActiveXObject, 
 isMozilla:(
typeof document.implementation != 'undefined'&& (typeof document.implementation.createDocument != 'undefined'&& (typeof HTMLDocument!='undefined'
 }
;
 
var loadDocument = function (fileStr) {
 
if (!fileStr) throw new Error([65221"调用XMLHTTP错误,没有指定文件名。"]);
 
var req = browser.isIE?new ActiveXObject("MSXML2.XMLHTTP"):new XMLHttpRequest();
 req.open(
"GET", fileStr, false);
 req.send(
null); 
 
if (req.readyState==4 && req.status==200return req.responseXML; }
 
else throw new Error([65222"调用XMLHTTP错误,远程文件失败。"+fileStr+""]);
 }

 
var ready2Transform = function () {
 xmlDocument 
= loadDocument(xmlfileStr);
 xslStylesheet 
= loadDocument(xslfileStr);
 }
(); 
 
var parseFromMoz = function () {
 
var xsltProcessor = new XSLTProcessor();
 xsltProcessor.importStylesheet(xslStylesheet);
 
var retval = xsltProcessor.transformToDocument(xmlDocument);
 
return (new XMLSerializer()).serializeToString(retval);//序列化
 }

 
var parseFromIE = function () {
 
return xmlDocument.transformNode(xslStylesheet.documentElement);
 }

 
if (browser.isMozilla) 
 retval 
= parseFromMoz(xmlfileStr, xslfileStr); 
 }
 
 
else if (browser.isIE) 
 retval 
= parseFromIE(xmlfileStr, xslfileStr);
 }
 else /* TO DO */ ;}return retval;
 }

 document.getElementById(
"demo").innerHTML=xsltParser("foo.xml","foo.xsl")
//]]>
</script>
 
</body>
</html>
 

发表于 @ 2006年07月31日 14:44:00|评论(loading...)|编辑

新一篇: 如何让动态插入的javascript脚本代码跑起来。 | 旧一篇: 用XHTML CSS做漂亮的阴影菜单

评论:没有评论。

发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © never-online