Ajax用法-基本语法

前端之家收集整理的这篇文章主要介绍了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",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": "中国" },status) {
                alert(data);
            });

猜你在找的Ajax相关文章