Rumah pembangunan bahagian belakang Tutorial XML/RSS XML卷之实战锦囊(1):动态排序

XML卷之实战锦囊(1):动态排序

Feb 10, 2017 pm 04:09 PM
xml pengisihan dinamik

动机:
排序功能让我们页面上的数据显的更人性化,是我们在网站上见过的很普遍的一个功能效果了。以往的自动排序都是用大量的脚本代码来完成的,对一般的爱好者来说这是件困难的事情。然而用XML来处理的话就简单多了。让自己的页面更加绚丽,哈哈,您是不是也心动了呢!

材料:
XML卷之动态排序
有2个文件:paixu.xml 和 paixu.xsl

作用:
在不刷新页面的情况下更据用户自己的需要对数据重新进行排序显示,有效的提高数据互动功能,让自己的页面更加绚丽多彩。 
效果:
浏览这里 
代码:
paixu.xml

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

<?xml version="1.0" encoding="gb2312" ?>

<?xml-stylesheet type="text/xsl" href="paixu.xsl" ?>

<BlueIdea>

  <team>

    <blue_ID>1</blue_ID>

    <blue_name>Sailflying</blue_name>

    <blue_text>一个简单的排序</blue_text>

    <blue_time>2002-1-11 17:35:33</blue_time>

    <blue_class>XML专题</blue_class>

  </team>

  <team>

    <blue_ID>2</blue_ID>

    <blue_name>flyingbird</blue_name>

    <blue_text>嫁给你,是要你疼的</blue_text>

    <blue_time>2001-09-06 12:45:51</blue_time>

    <blue_class>灌水精华</blue_class>

  </team>

  <team>

    <blue_ID>3</blue_ID>

    <blue_name>苛子</blue_name>

    <blue_text>正则表达式在UBB论坛中的应用</blue_text>

    <blue_time>2001-11-23 21:02:16</blue_time>

    <blue_class>Web 编程精华</blue_class>

  </team>

  <team>

    <blue_ID>4</blue_ID>

    <blue_name>太乙郎</blue_name>

    <blue_text>年末经典分舵聚会完全手册 v0.1</blue_text>

    <blue_time>2000-12-08 10:22:48</blue_time>

    <blue_class>论坛灌水区</blue_class>

  </team>

  <team>

    <blue_ID>5</blue_ID>

    <blue_name>mmkk</blue_name>

    <blue_text>Asp错误信息总汇</blue_text>

    <blue_time>2001-10-13 16:39:05</blue_time>

    <blue_class>javascript脚本</blue_class>

  </team>

</BlueIdea>

Salin selepas log masuk


paixu.xsl

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

<?xml version="1.0" encoding="gb2312" ?>

<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">

<xsl:template match="/">

<html>

<head>

<title> XML卷之实战锦囊(1):动态排序</title>

<style>

body,BlueIdea,team,blue_ID,blue_name,blue_text,blue_time,blue_class{ font: 12px "宋体", "Arial", "Times New Roman"; }

table

{

font-size: 12px; border: 0px double;

border-color: #99CC99 #99CC99 #CCCCCC #CCCCCC;

cellpadding:3;cellspacing:3; bgcolor:#eeeeee;

text-decoration: blink}

span { font-size: 12px; color: red; }

</style>

<script>

function taxis(x)

{

stylesheet=document.XSLDocument;

source=document.XMLDocument;

sortField=document.XSLDocument.selectSingleNode("//@order-by");

sortField.value=x;

Layer1.innerHTML=source.documentElement.transformNode(stylesheet);

}

</script>

</head>

<body>

<p align="center"><span>XML卷之实战锦囊(1):动态排序</span></p>

<p id="Layer1" name="Layer1">

<xsl:apply-templates select="BlueIdea" />

</p>

</body>

</html>

</xsl:template>

<xsl:template match="BlueIdea">

<table width="500" border="1" align="center" cellpadding="1" cellspacing="1" bordercolordark="#ffffff" bordercolorlight="#ADAAAD">

<tr bgcolor="#FFCC99" align="center">

<td style="cursor:s-resize" onClick="taxis(&#39;blue_ID&#39;)">编号</td>

<td style="cursor:s-resize" onClick="taxis(&#39;blue_name&#39;)">姓名</td>

<td style="cursor:s-resize" onClick="taxis(&#39;blue_text&#39;)">主题</td>

<td style="cursor:s-resize" onClick="taxis(&#39;blue_time&#39;)">发表时间</td>

<td style="cursor:s-resize" onClick="taxis(&#39;blue_class&#39;)">归类</td>

</tr>

<xsl:apply-templates select="team" order-by="blue_ID"/>

</table>

</xsl:template>

<xsl:template match="team">

<tr align="center">

<xsl:apply-templates select="blue_ID" />

<xsl:apply-templates select="blue_name" />

<xsl:apply-templates select="blue_text" />

<xsl:apply-templates select="blue_time" />

<xsl:apply-templates select="blue_class" />

</tr>

</xsl:template>

<xsl:template match="blue_ID">

<td bgcolor="#eeeeee">

<xsl:value-of />

</td>

</xsl:template>

<xsl:template match="blue_name">

<td>

<xsl:value-of />

</td>

</xsl:template>

<xsl:template match="blue_text">

<td>

<xsl:value-of />

</td>

</xsl:template>

<xsl:template match="blue_time">

<td>

<xsl:value-of />

</td>

</xsl:template>

<xsl:template match="blue_class">

<td>

<xsl:value-of />

</td>

</xsl:template>

</xsl:stylesheet>

Salin selepas log masuk


讲解:
1)paixu.xml 是数据文件,相信大家都不会有问题。
2)paixu.xsl 是格式文件,有几个地方要注意。
(1)脚本中:

sortField=document.XSLDocument.selectSingleNode("//@order-by");
作用是:找到有属性为order-by的第一个节点,因此它对应的节点就是

因此在初次onLoad的时候order-by的value值是blue_ID。
而我们就是通过重新定义order-by的value值来达到排序的目的。

1

Layer1.innerHTML=source.documentElement.transformNode(stylesheet);

Salin selepas log masuk


作用是:转化XML数据后更改Layer1,因此在传出参数'blue_name'后,

1

<td style="cursor:s-resize" onClick="taxis(&#39;blue_name)">姓名</td>

Salin selepas log masuk


我们将order-by的value值修改为是'blue_name',即以'blue_name'为排序方式。
继而通过重新显示Layer1的innerHTML值来显示新的排序内容。

(2)文本中:

order-by
这个可不能少哦,不然就找不到了,效果嘛,你瞧瞧看吧!!

1

<?xml version="1.0" encoding="gb2312" ?>

Salin selepas log masuk

在大多的XML教科书中所显示的代码中很少会加上encoding="gb2312" ,
因此我们在XML中用到中文的时候会报错,原因就是没有写这个申明。

 

后记:
大家熟悉动态排序完成思路后会发现,其实我们的实现手法很简单。
就是修改order-by的数值,然后重新显示。
在动态查询和动态分页的功能中我们依然是按照这个思路去完成的。 

以上就是XML卷之实战锦囊(1):动态排序的内容,更多相关内容请关注PHP中文网(www.php.cn)!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bolehkah saya membuka fail XML menggunakan PowerPoint? Bolehkah saya membuka fail XML menggunakan PowerPoint? Feb 19, 2024 pm 09:06 PM

Bolehkah fail XML dibuka dengan PPT? XML, Extensible Markup Language (Extensible Markup Language), ialah bahasa markup universal yang digunakan secara meluas dalam pertukaran data dan penyimpanan data. Berbanding dengan HTML, XML lebih fleksibel dan boleh menentukan tag dan struktur datanya sendiri, menjadikan penyimpanan dan pertukaran data lebih mudah dan bersatu. PPT, atau PowerPoint, ialah perisian yang dibangunkan oleh Microsoft untuk membuat pembentangan. Ia menyediakan cara yang komprehensif untuk

Menggunakan Python untuk menggabungkan dan menyahduplikasi data XML Menggunakan Python untuk menggabungkan dan menyahduplikasi data XML Aug 07, 2023 am 11:33 AM

Menggunakan Python untuk menggabungkan dan menyahduplikasi data XML XML (eXtensibleMarkupLanguage) ialah bahasa penanda yang digunakan untuk menyimpan dan menghantar data. Apabila memproses data XML, kadangkala kita perlu menggabungkan berbilang fail XML menjadi satu, atau mengalih keluar data pendua. Artikel ini akan memperkenalkan cara menggunakan Python untuk melaksanakan penggabungan dan penyahduplikasian data XML, dan memberikan contoh kod yang sepadan. 1. Penggabungan data XML Apabila kita mempunyai berbilang fail XML, kita perlu menggabungkannya

Tukar data XML kepada format CSV dalam Python Tukar data XML kepada format CSV dalam Python Aug 11, 2023 pm 07:41 PM

Tukar data XML dalam Python kepada format CSV XML (ExtensibleMarkupLanguage) ialah bahasa penanda boleh diperluas yang biasa digunakan untuk penyimpanan dan penghantaran data. CSV (CommaSeparatedValues) ialah format fail teks dipisahkan koma yang biasa digunakan untuk import dan eksport data. Semasa memproses data, kadangkala data XML perlu ditukar kepada format CSV untuk analisis dan pemprosesan yang mudah. Python adalah yang kuat

Menapis dan menyusun data XML menggunakan Python Menapis dan menyusun data XML menggunakan Python Aug 07, 2023 pm 04:17 PM

Melaksanakan penapisan dan pengisihan data XML menggunakan Python Pengenalan: XML ialah format pertukaran data yang biasa digunakan yang menyimpan data dalam bentuk teg dan atribut. Apabila memproses data XML, kami selalunya perlu menapis dan mengisih data. Python menyediakan banyak alat dan perpustakaan yang berguna untuk memproses data XML. Artikel ini akan memperkenalkan cara menggunakan Python untuk menapis dan mengisih data XML. Membaca fail XML Sebelum kita mula, kita perlu membaca fail XML. Python mempunyai banyak perpustakaan pemprosesan XML,

Import data XML ke dalam pangkalan data menggunakan PHP Import data XML ke dalam pangkalan data menggunakan PHP Aug 07, 2023 am 09:58 AM

Mengimport data XML ke dalam pangkalan data menggunakan PHP Pengenalan: Semasa pembangunan, kita sering perlu mengimport data luaran ke dalam pangkalan data untuk pemprosesan dan analisis selanjutnya. Sebagai format pertukaran data yang biasa digunakan, XML sering digunakan untuk menyimpan dan menghantar data berstruktur. Artikel ini akan memperkenalkan cara menggunakan PHP untuk mengimport data XML ke dalam pangkalan data. Langkah 1: Menghuraikan fail XML Mula-mula, kita perlu menghuraikan fail XML dan mengekstrak data yang diperlukan. PHP menyediakan beberapa cara untuk menghuraikan XML, yang paling biasa digunakan ialah menggunakan Mudah

Python melaksanakan penukaran antara XML dan JSON Python melaksanakan penukaran antara XML dan JSON Aug 07, 2023 pm 07:10 PM

Python melaksanakan penukaran antara XML dan JSON Pengenalan: Dalam proses pembangunan harian, kita selalunya perlu menukar data antara format yang berbeza. XML dan JSON ialah format pertukaran data biasa Dalam Python, kita boleh menggunakan pelbagai perpustakaan untuk menukar antara XML dan JSON. Artikel ini akan memperkenalkan beberapa kaedah yang biasa digunakan, dengan contoh kod. 1. Untuk menukar XML kepada JSON dalam Python, kita boleh menggunakan modul xml.etree.ElementTree

Mengendalikan ralat dan pengecualian dalam XML menggunakan Python Mengendalikan ralat dan pengecualian dalam XML menggunakan Python Aug 08, 2023 pm 12:25 PM

Mengendalikan Ralat dan Pengecualian dalam XML Menggunakan Python XML ialah format data yang biasa digunakan untuk menyimpan dan mewakili data berstruktur. Apabila kami menggunakan Python untuk memproses XML, kadangkala kami mungkin menghadapi beberapa ralat dan pengecualian. Dalam artikel ini, saya akan memperkenalkan cara menggunakan Python untuk mengendalikan ralat dan pengecualian dalam XML, dan menyediakan beberapa kod sampel untuk rujukan. Gunakan pernyataan cuba-kecuali untuk menangkap ralat penghuraian XML Apabila kami menggunakan Python untuk menghuraikan XML, kadangkala kami mungkin menghadapi beberapa

Python menghuraikan aksara khas dan urutan melarikan diri dalam XML Python menghuraikan aksara khas dan urutan melarikan diri dalam XML Aug 08, 2023 pm 12:46 PM

Python menghuraikan aksara khas dan jujukan melarikan diri dalam XML XML (eXtensibleMarkupLanguage) ialah format pertukaran data yang biasa digunakan untuk memindahkan dan menyimpan data antara sistem yang berbeza. Semasa memproses fail XML, anda sering menghadapi situasi yang mengandungi aksara khas dan urutan melarikan diri, yang boleh menyebabkan ralat penghuraian atau salah tafsiran data. Oleh itu, apabila menghuraikan fail XML menggunakan Python, kita perlu memahami cara mengendalikan aksara khas dan urutan melarikan diri ini. 1. Watak istimewa dan

See all articles