使用javascript访问XML数据的实例_javascript技巧
在网络浏览器软件中,可以Internet Explorer (IE)现在是一种标准的软件。可以看到,运行不同版本的Windows操作系统(和很多其他的操作系统)的每一台机器几乎都使用IE。微软已经通过ActiveX控件将IE的功能包含在执行成熟的XML处理技术中。
在本篇文章中,我们将讲述如何在IE中使用ActiveX功能来访问并解析XML文档,由此允许网络冲浪者操纵它们。
网上冲浪
我们以一个标准的顺序文档而开始,如表A所示。这一文档包含简单的顺序数据以提供网络冲浪者浏览之用。不仅仅为了显示这些数据,我们还提供了一个简单的用户界面,网上冲浪都可以使用这一界面来浏览XML文档。
表A: order.xml
我们使用一个网络表单以访问这一XML文档,这一表单将显示SKU,价格,数量,各部分的小计,以及顺序中的每一选项的描述。我们的表单还包含向前和向后浏览选项的按钮。
网页的构成
网页的重要部分是在于表单,我们将使用一个表以易读的方式在屏幕上显示。下面是显示HTML表的代码片段:
请注意到,我们在表的下面包含了两个按钮,即通过getDataNext() 和getDataPrev()函数来浏览前一个和后一个的记录,这也是我们所要讨论的问题。
脚本
其实,我们网页的实质部分不是在于表单,而是在于控制表单的脚本。在我们的脚本中包括四个部分。首先,我们通过载入XML文档而初始化网页。第二部分是导航到下一个记录。第三步是导航到前一个记录。第四部分是从XML文档中提取单一的值。表B显示了我们的网页的全部内容。
表B: jsxml.html
<script> <BR><!-- <BR> vari = -1; <BR> varorderDoc = new ActiveXObject("MSXML2.DOMDocument.3.0"); <BR> orderDoc.load("order.xml"); <BR> var items = orderDoc.selectNodes("/Order/Item"); <BR> <BR> function getNode(doc, xpath) { <BR> varretval = ""; <BR> var value = doc.selectSingleNode(xpath); <BR> if (value) retval = value.text; <BR> return retval; <BR> } <BR> <BR> function getDataNext() { <BR> i++; <BR> if (i > items.length - 1) i = 0; <br><br> document.forms[0].SKU.value = getNode(orderDoc, "/Order/Item[" + <BR>i + "]/SKU"); <BR> document.forms[0].Price.value = getNode(orderDoc, "/Order/Item[" <BR>+ i + "]/PricePer"); <BR> document.forms[0].Quantity.value = getNode(orderDoc, <BR>"/Order/Item[" + i + "]/Quantity"); <BR> document.forms[0].Total.value = getNode(orderDoc, "/Order/Item[" <BR>+ i + "]/Subtotal"); <BR> document.forms[0].Description.value = getNode(orderDoc, <BR>"/Order/Item[" + i + "]/Description"); <BR> } <BR> <BR> function getDataPrev() { <BR> i--; <BR> if (i < 0) i = items.length - 1; <BR> <BR> document.forms[0].SKU.value = getNode(orderDoc, "/Order/Item[" + <BR>i + "]/SKU"); <BR> document.forms[0].Price.value = getNode(orderDoc, "/Order/Item[" <BR>+ i + "]/PricePer"); <BR> document.forms[0].Quantity.value = getNode(orderDoc, <BR>"/Order/Item[" + i + "]/Quantity"); <BR> document.forms[0].Total.value = getNode(orderDoc, "/Order/Item[" <BR>+ i + "]/Subtotal"); <BR> document.forms[0].Description.value = getNode(orderDoc, <BR>"/Order/Item[" + i + "]/Description"); <BR> } <BR> <BR>// --> <BR> </script>
XML order Database
运行
这一网页将传入并运行脚本的初始化。你一定确保order.xml文档与jsxml.html在相同的相同的路径上。
初始化部分将一个新的ActiveX对象例示为MSXML2.DOMDocument.3.0对象类型,然后脚本传入order.xml文档到内存中,并选择所有的/Order/Item节点。我们使用/Order/Item节点以识别文档已经包含的选项。
文档中的标准有一个onLoad属性,这一属性能够使得网页调用getDataNext()而初始化。这一功能可用于从XML文档中获得下一个值并显示在表单中。我们使用一个简单的索引来访问特定的选项。
向前(>>)和向后(

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

如何在JavaScript中将具有相同ID的数组元素合并到一个对象中?在处理数据时,我们常常会遇到需要将具有相同ID�...

实现视差滚动和元素动画效果的探讨本文将探讨如何实现类似资生堂官网(https://www.shiseido.co.jp/sb/wonderland/)中�...

深入探讨console.log输出差异的根源本文将分析一段代码中console.log函数输出结果的差异,并解释其背后的原因。�...

学习JavaScript不难,但有挑战。1)理解基础概念如变量、数据类型、函数等。2)掌握异步编程,通过事件循环实现。3)使用DOM操作和Promise处理异步请求。4)避免常见错误,使用调试技巧。5)优化性能,遵循最佳实践。

探索前端中类似VSCode的面板拖拽调整功能的实现在前端开发中,如何实现类似于VSCode...
