使用 JavaScript 实现 XMLHttpRequest,在IE,FireFox 上测试通过!

javascript|request|xml|xmlhttprequest

XMLHttp 方式实现无刷屏,在IE,FireFox 上测试通过

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  "http://www.w3.org/tr/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<style>
html {background-color:#eeeeee}
body {
      background-color:#ccffcc;
      font-family:Tahoma,Arial,Helvetica,sans-serif;
      font-size:12px;
   margin-left:15%;
   margin-right:15%;
   border:3px groove #006600;
   padding:15px
  }
h1   {
      text-align:left;
      font-size:1.5em;
      font-weight:bold
     }
</style>
<script type="text/javascript">
// global flag
var isIE = false;

// global request and XML document objects
var req;

// retrieve XML document (reusable generic function);
// parameter is URL string (relative or complete) to
// an .xml file whose Content-Type is a valid XML
// type, such as text/xml; XML source must be from
// same domain as HTML file
function loadXMLDoc(url) {
    // branch for native XMLHttpRequest object
    if (window.XMLHttpRequest) {
        req = new XMLHttpRequest();
        req.onreadystatechange = processReqChange;
        req.open("GET", url, true);
        req.send(null);
    // branch for IE/Windows ActiveX version
    } else if (window.ActiveXObject) {
        isIE = true;
        req = new ActiveXObject("Microsoft.XMLHTTP");
        if (req) {
            req.onreadystatechange = processReqChange;
            req.open("GET", url, true);
            req.send();
        }
    }
}

// handle onreadystatechange event of req object
function processReqChange() {
    // only if req shows "loaded"
    if (req.readyState == 4) {
        // only if "OK"
        if (req.status == 200) {
            clearTopicList();
            buildTopicList();
         } else {
            alert("There was a problem retrieving the XML data:\n" +
                req.statusText);
         }
    }
}

// invoked by "Category" select element change;
// loads chosen XML document, clears Topics select
// element, loads new items into Topics select element
function loadDoc(evt) {
    // equalize W3C/IE event models to get event object
    evt = (evt) ? evt : ((window.event) ? window.event : null);
    if (evt) {
        // equalize W3C/IE models to get event target reference
        var elem = (evt.target) ? evt.target : ((evt.srcElement) ? evt.srcElement : null);
        if (elem) {
            try {
                if (elem.selectedIndex > 0) {
                    loadXMLDoc(elem.options[elem.selectedIndex].value);
                }
            }
            catch(e) {
                var msg = (typeof e == "string") ? e : ((e.message) ? e.message : "Unknown Error");
                alert("Unable to get XML data:\n" + msg);
                return;
            }
        }
    }
}

// retrieve text of an XML document element, including
// elements using namespaces
function getElementTextNS(prefix, local, parentElem, index) {
    var result = "";
    if (prefix && isIE) {
        // IE/Windows way of handling namespaces
        result = parentElem.getElementsByTagName(prefix + ":" + local)[index];
    } else {
        // the namespace versions of this method
        // (getElementsByTagNameNS()) operate
        // differently in Safari and Mozilla, but both
        // return value with just local name, provided
        // there aren't conflicts with non-namespace element
        // names
        result = parentElem.getElementsByTagName(local)[index];
    }
    if (result) {
        // get text, accounting for possible
        // whitespace (carriage return) text nodes
        if (result.childNodes.length > 1) {
            return result.childNodes[1].nodeValue;
        } else {
            return result.firstChild.nodeValue;     
        }
    } else {
        return "n/a";
    }
}

// empty Topics select list content
function clearTopicList() {
    var select = document.getElementById("topics");
    while (select.length > 0) {
        select.remove(0);
    }
}

// add item to select element the less
// elegant, but compatible way.
function appendToSelect(select, value, content) {
    var opt;
    opt = document.createElement("option");
    opt.value = value;
    opt.appendChild(content);
    select.appendChild(opt);
}

// fill Topics select list with items from
// the current XML document
function buildTopicList() {
    var select = document.getElementById("topics");
    var items = req.responseXML.getElementsByTagName("item");
    // loop through <item> elements, and add each nested
    // <title> element to Topics select element
    for (var i = 0; i < items.length; i++) {
        appendToSelect(select, i,
            document.createTextNode(getElementTextNS("", "title", items[i], 0)));
    }
    // clear detail display
    document.getElementById("details").innerHTML = "";
}

// display details retrieved from XML document
function showDetail(evt) {
    evt = (evt) ? evt : ((window.event) ? window.event : null);
    var item, content, div;
    if (evt) {
        var select = (evt.target) ? evt.target : ((evt.srcElement) ? evt.srcElement : null);
        if (select && select.options.length > 1) {
            // copy <content:encoded> element text for
            // the selected item
            item = req.responseXML.getElementsByTagName("item")[select.value];
            content = getElementTextNS("content", "encoded", item, 0);
            div = document.getElementById("details");
            div.innerHTML = "";
            // blast new HTML content into "details" <div>
            div.innerHTML = content;
        }
    }
}
</script>
</head>
<body>
<h1>XMLHttpRequest Object Demo</h1>
<hr />

<form>
<p>Category:<br />
<select >
    <option value="">Choose One</option>
    <option value="songs.xml">Top 10 Songs</option>
    <option value="albums.xml">Top 10 Albums</option>
    <option value="newreleases.xml">Top 10 New Releases</option>
    <option value="justadded.xml">Top 10 Just Added</option>
</select>
</p>
<p>Items:<br />
<select size="10" id="topics" >
    <option value="">Choose a Category First</option>
</select>
</p>
</form>
<div id="details"><span></span></div>
</body>
<html>

 

时间: 2024-10-02 15:16:58

使用 JavaScript 实现 XMLHttpRequest,在IE,FireFox 上测试通过!的相关文章

使用 JavaScript 实现 XMLHttpRequest

javascript|request|xml|xmlhttprequest XMLHttp 方式实现无刷屏,在IE,FireFox 上测试通过 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"   "http://www.w3.org/tr/xhtml1/DTD/xhtml1-transitional.dtd"><html><head><style&

javascript实现获取指定精度的上传文件的大小简单实例_javascript技巧

js实现获取指定精度的上传文件的大小,主要采用html和JavaScript,用浏览器运行下述代码,按照操作:选择文件->获得文件大小的顺序,即可. 源码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>获得文件大小</title> </head> <body> <f

如何在电脑上测试手机网站(全)

原文:如何在电脑上测试手机网站(全) 最近公司要开发网站的移动版,让我准备准备知识,话说本人开发移动网站的经验还真不多,最悲剧的事情就是我的手机是个经典的诺基亚,而且公司还不给配手机,这是有多讨厌,没办法,没有手机只能用电脑模拟了,相办法代替,查了很多资料,尝试了大部分方法,下面将这一天的努力总结下分享给大家,也让大家免去看那么多文章,以下介绍的方法,都是本人亲自测试成功的方法,测试环境winxp. Chrome* chrome模拟手机总共有四种方法,原理都一样,通过伪装User-Agent,将

《编写可测试的JavaScript代码》——第1章 可测试的JavaScript

第1章 可测试的JavaScript 每个人的想法都是独一无二的,但代码不是.几乎每个行业都完成了机器革命,然而奇怪的是,计算机科学行业并没有.程序员基本上是在做已经做了40年的同样的事情.手工编写代码,接着这些代码被编译或解释,然后执行.看看输出结果,再确定是否需要再改代码.计算机科学的黎明到来之前,这种开发周期就一直这样保持不变.我们的机器在几何级变快,内存和二级存储大小是无限制的,且这样发展下去软件越来越复杂.但我们仍然一个字母一个键地手工编写着代码.我们依然滥用着"print"

《编写可测试的JavaScript代码》——第1章 可测试的JavaScript 1.1 现有技术

第1章 可测试的JavaScript 每个人的想法都是独一无二的,但代码不是.几乎每个行业都完成了机器革命,然而奇怪的是,计算机科学行业并没有.程序员基本上是在做已经做了40年的同样的事情.手工编写代码,接着这些代码被编译或解释,然后执行.看看输出结果,再确定是否需要再改代码.计算机科学的黎明到来之前,这种开发周期就一直这样保持不变.我们的机器在几何级变快,内存和二级存储大小是无限制的,且这样发展下去软件越来越复杂.但我们仍然一个字母一个键地手工编写着代码.我们依然滥用着"print"

服务器-乱码问题在本地测试没有问题,提交SVn合入代码之后在服务其上测试就不行?

问题描述 乱码问题在本地测试没有问题,提交SVn合入代码之后在服务其上测试就不行? 在前台我使用encodeURIComponent转码在后天使用String 的构造方法进行解码,然后再本地上测试没有问题,到服务器上就不行了,怎么回事? 解决方案 服务器和本地环境有什么差别?比如JRE的配置.语言配置等,本地是什么环境,服务器是什么环境? 解决方案二: 原来服务器用的是tomcat8了,本地是7

camera-做了一款引用,在别的手机上测试都没有问题,可以正常打开手机拍照,但是用了华为Mate 8 出现了问题

问题描述 做了一款引用,在别的手机上测试都没有问题,可以正常打开手机拍照,但是用了华为Mate 8 出现了问题 问题就是:我把手机照片放在了/mnt/sdcard/DCIM/Camera这个目录下,才导致程序在华为上无法执行,是我写错了,还是华为上的照片路径特殊? 解决方案 可以具体说下在华为Mate 8出了什么问题么? 解决方案二: 就是我在做照相机功能的时候,我点击按钮进行照相,但是照相不成功,错误好像就是出现在这个路径上个,我现在正在进行异常捕获测试,看看是不是路径不存在.但是我用比Mat

怎么实现 在一台手机上测试app,另外几台手机也执行同样测试的动作

问题描述 怎么实现 在一台手机上测试app,另外几台手机也执行同样测试的动作 我需要测试app在不同手机上的兼容性. 我想自己开发一种工具,让我在一台手机上测试app,另外几台手机也会执行同样的动作! 求思路或者源码!! 解决方案 我有个想法,不知道你对 node的是否了解, node 可以建立一个 通信的服务器,把客户端的操作 群发给每个客户端,对应的客户端,进行你的所有操作 步骤: 1:安装一个node 2:编写一个http的服务 3:所有的网页 链接这个服务器 4:编写 监听操作,并写到一

settheme-android在程序中用setTheme设置主题,小米2上测试无效,大牛求解~

问题描述 android在程序中用setTheme设置主题,小米2上测试无效,大牛求解- @Override public void onCreate(Bundle savedInstanceState) { setTheme(R.style.translucent); requestWindowFeature(Window.FEATURE_NO_TITLE); super.onCreate(savedInstanceState); setContentView(R.layout.myview)