XSLT - ¿Í»§¶Ë

Èç¹ûÄúµÄä¯ÀÀÆ÷Ö§³Ö XSLT£¬ÄÇôÔÚä¯ÀÀÆ÷ÖÐËü¿É±»ÓÃÀ´½«Îĵµ×ª»»Îª XHTML¡£

JavaScript ½â¾ö·½°¸

ÔÚÇ°ÃæµÄÕ½ڣ¬ÎÒÃÇÒÑÏòÄú½²½âÈçºÎʹÓà XSLT ½«Ä³¸ö XML Îĵµ×ª»»Îª XHTML¡£ÎÒÃÇÊÇͨ¹ýÒÔÏÂ;¾¶Íê³ÉÕâ¸ö¹¤×÷µÄ£ºÏò XML ÎļþÌí¼Ó XSL Ñùʽ±í£¬²¢Í¨¹ýä¯ÀÀÆ÷Íê³Éת»»¡£

¼´Ê¹ÕâÖÖ·½·¨µÄЧ¹ûºÜºÃ£¬ÔÚ XML ÎļþÖаüº¬Ñùʽ±íÒýÓÃÒ²²»×ÜÊÇÁîÈËÂúÒâµÄ£¨ÀýÈ磬ÔÚÎÞ·¨Ê¶±ðXSLTµÄä¯ÀÀÆ÷ÕâÖÖ·½·¨¾ÍÎÞ·¨×àЧ£©¡£

¸üͨÓõķ½·¨ÊÇʹÓà JavaScript À´Íê³Éת»»¡£

ͨ¹ýʹÓà JavaScript£¬ÎÒÃÇ¿ÉÒÔ£º

  • ½øÐÐä¯ÀÀÆ÷È·ÈϲâÊÔ
  • ¸ù¾Ýä¯ÀÀÆ÷ºÍʹÓÃÕßµÄÐèÇóÀ´Ê¹Óò»Í¬µÄÑùʽ±í

Õâ¾ÍÊÇ XSLT µÄ÷ÈÁ¦ËùÔÚ£¡XSLT µÄÉè¼ÆÄ¿µÄÖ®Ò»¾ÍÊÇʹһÖÖ¸ñʽµ½ÁíÒ»ÖÖ¸ñʽµÄת»»³ÉΪ¿ÉÄÜ£¬Í¬Ê±Ö§³Ö²»Í¬ÀàÐ͵Ää¯ÀÀÆ÷ÒÔ¼°²»Í¬µÄÓû§ÐèÇó¡£

ä¯ÀÀÆ÷¶ËµÄ XSLT ת»»Ò»¶¨»á³ÉΪδÀ´ä¯ÀÀÆ÷ËùÖ´ÐеÄÖ÷ÒªÈÎÎñÖ®Ò»£¬Í¬Ê±ÎÒÃÇÒ²»á¿´µ½ÆäÔÚÌØ¶¨µÄä¯ÀÀÆ÷Êг¡µÄÔö³¤£¨Ã¤ÎÄ¡¢ÍøÂç´òÓ¡»ú£¬Ìý¾õÉ豸£¬µÈµÈ£©¡£

XML ÎļþºÍ XSL Îļþ

Çë¿´Õâ¸öÔÚÇ°ÃæµÄÕ½ÚÒÑչʾ¹ýµÄ XML Îĵµ£º

<?xml version="1.0" encoding="ISO-8859-1"?>
<catalog>
  <cd>
    <title>Empire Burlesque</title>
    <artist>Bob Dylan</artist>
    <country>USA</country>
    <company>Columbia</company>
    <price>10.90</price>
    <year>1985</year>
  </cd>
.
.
.
</catalog>

²é¿´´Ë XML Îļþ¡£

ÒÔ¼°¸½ËæµÄ XSL Ñùʽ±í£º

<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:template match="/">
  <html>
  <body>
    <h2>My CD Collection</h2> 
    <table border="1">
      <tr bgcolor="#9acd32">
        <th align="left">Title</th> 
        <th align="left">Artist</th> 
      </tr>
      <xsl:for-each select="catalog/cd">
      <tr>
        <td><xsl:value-of select="title" /></td>
        <td><xsl:value-of select="artist" /></td>
      </tr>
      </xsl:for-each>
  </table>
  </body>
  </html>
</xsl:template>

</xsl:stylesheet>

²é¿´´Ë XSL Îļþ¡£

Çë×¢Ò⣬Õâ¸ö XML ÎļþûÓаüº¬¶Ô XSL ÎļþµÄÒýÓá£

ÖØÒªÊÂÏÉÏÃæÕâ¾ä»°Òâζ×Å£¬XML Îļþ¿ÉʹÓöà¸ö²»Í¬µÄ XSL Ñùʽ±íÀ´½øÐÐת»»¡£

ÔÚä¯ÀÀÆ÷ÖÐ°Ñ XML ת»»Îª XHTML

ÕâÊÇÓÃÓÚÔÚ¿Í»§¶Ë°Ñ XML Îļþת»»Îª XHTML µÄÔ´´úÂ룺

<html>
<body>

<script type="text/javascript">

// Load XML 
var xml = new ActiveXObject("Microsoft.XMLDOM")
xml.async = false
xml.load("cdcatalog.xml")

// Load XSL
var xsl = new ActiveXObject("Microsoft.XMLDOM")
xsl.async = false
xsl.load("cdcatalog.xsl")

// Transform
document.write(xml.transformNode(xsl))

</script>

</body>
</html>

Ìáʾ£º¼ÙÈçÄú²»Á˽âÈçºÎ±àд JavaScript£¬ÇëѧϰÎÒÃǵġ¶JavaScript ½Ì³Ì¡·¡£

µÚÒ»¶Î´úÂë´´½¨ÁË΢ÈíµÄ XML ½âÎöÆ÷µÄÒ»¸öʵÀý£¬È»ºó°Ñ XML ÎļþÔØÈëÁËÄÚ´æ¡£µÚ¶þ¶Î´úÂë´´½¨Á˽âÎöÆ÷µÄÁíÒ»¸öʵÀý£¬È»ºó°ÑÕâ¸ö XSL ÎļþÔØÈëÁËÄÚ´æ¡£×îºóÒ»ÐдúÂëʹÓà XSL Îĵµ×ª»»ÁË XML Îĵµ£¬²¢ÔÚä¯ÀÀÆ÷Öаѽá¹û×÷Ϊ XHTML ÏÔʾ³öÀ´¡£ÈÎÎñÍê³É£¡

Çë¿´ËüÔÚ IE ÖÐÈçºÎ¹¤×÷¡£

VUE