Ajax用法-基本语法

一. Javascript实现Ajax

function btnClick() {
            //创建访问服务器的对象(只对IE有效)
            var xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
            //准备请求open(请求方式GET/POST,请求地址,是否异步)
            xmlHttp.open("GET", "GetTime.ashx", false);
            //注册请求状态改变的事件
            xmlHttp.onreadystatechange = function () {
                //如果请求成功
                if (xmlHttp.readyState == 4 && xmlHttp.status == 200) {
                    //获得请求返回的数据
                    var str = xmlHttp.responseText;
                    //显示
                    alert(str);
                }
            }
            //发送请求
            xmlHttp.send();
        }

这里需要注意:

1.缓存问题

 xmlHttp.open("GET", "GetTime.ashx", false);

如果请求方式是GET,会存在缓存问题,如果请求方式是POST,一般不会存在缓存问题。为了在两种请求方式下都能够避免缓存问题,可用下面的代码

xmlHttp.open("POST", "Handler1.ashx?sm=" + new Date(), false);
在请求地址中将的当前时间作为参数,参数不同即url不同,也就避免了缓存的问题。


2. 参数问题

如果传递非中文参数

xmlHttp.open("POST", "Handler1.ashx?param=China", false);

如果传递中文参数

 xmlHttp.open("POST", "Handler1.ashx?param=" + encodeURI("中国"), false);


二. JQuery 实现Ajax

上面使用Javascript实现Ajax有许多需要注意的地方,且代码量大,相比之下,JQuery就要简单得多。

function btnClick2() {
            // post(请求地址,请求完成后客户端执行的方法(返回的数据,请求的状态));
            $.post("GetTime.ashx", function (data, status) {
                if (status == "success") {
                    alert(data);
                }
            });
        }

当然也有$.get()方法

对于参数问题,将不用再考虑中文的问题

//在post方法中的第二个位置可以加入参数,参数是以键值对的形式传入,{key1:value1,key2:value2,...}
            $.post("Handler1.ashx", { "param": "中国" }, function (data, status) {
                alert(data);
            });


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值