XMLHttpRequest对象 AJAX重点,AJAX下拉框

本文介绍如何使用XMLHttpRequest对象发送HTTP请求并处理响应,通过JavaScript动态加载下拉框选项。同时探讨了使用JSON格式简化复杂数据传输的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  创建XMLHttpReqeust对象.XmlHttpRequest使您可以使用JavaScript向服务器提出请求并处理响应,而不是HTTP请求。

 

        function CreateXMLHttp() {
            var xhr = false;
            try {
                xhr = new ActiveXObject("Msxml2.XMLHTTP");
            } catch (e) {

                try {
                    xhr = new ActiveXObject("Microsoft.XMLHTTP");
                } catch (e) {
                xhr = false;
              }
        }
        if (!xhr && typeof XMLHttpRequest != 'undefined') {
            xhr = new XMLHttpRequest();
        }
        return xhr;
        }
var xhr = false;
        window.onload = function () {
            xhr = createXmlHttp();
            Getjson();
        }

        function Getjson() {
            xhr.open("GET", "Do.ashx", true);
            xhr.onreadystatechange = function () {
                if (xhr.readyState == 4) {
                    if (xhr.status == 200) {
                        var Grades = gel("Grades");
                        var txt = xhr.responseText;
                        var txtArray = txt.split("|");
                        for (var i = 0; i < txtArray.length; i++) {
                            var StrArray = txtArray[i].split(",");
                            //alert(StrArray[0] + StrArray[1]);
                            var option1 = new Option(StrArray[1], StrArray[0]);
                            Grades.options.add(option1);
                       }
                   }
                }

            }
            xhr.send(null);
        }
 List<MODEL.Grades> list = new BLL.Grades().QueryListByCondition(null);
        System.Text.StringBuilder sbText = new System.Text.StringBuilder();
        foreach (MODEL.Grades model in list)
        {
            
            //1.年级
            sbText.Append(model.GID+","+model.GName+","+model.GIsDel+","+model.GAddtime+"|");
        }
        context.Response.Write(sbText.ToString().Substring(0,sbText.Length-2));//把最后的|去掉

三层结构,利用AJAX动态的加载下拉框. 上面用的是将实体对象,拼接成字符串,在Javascript中进行split。比较麻烦。下面用JSON格式来操作

AJAX传递复杂数据如果自己进行格式定义的话会经历组装、解析的过程,因此AJAX中有一个事实上的数据传输标准JSon。Json(是一个标准,就像XML一样,Json规定了对象以什么样的格式保存为一个字符串)将复杂对象序列化为一个字符串,在浏览器端再将字符串反序列化为JavaScript可以读取的对象。看一下Json的格式。Json被几乎所有语言支持。定义.

var json={"a":"111","b":"2222"};

json格式 以键值对格式存储的.



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值