Ajax 原理详细介绍

50 篇文章 0 订阅
43 篇文章 0 订阅

Ajax 的全称是Asynchronous JavaScript and XML

Ajax的优点:

1.最大的一点是页面无刷新,给用户的体验非常好。

2.使用异步方式与服务器通信,不需要打断用户的操作,具有更加迅速的响应能力。

3.ajax的原则是“按需取数据”,可以最大程度的减少冗余请求,减少服务器的负荷。

Ajax的缺点:

1.破坏浏览器后退按钮的正常行为。在动态更新页面后,用户无法回到前一个页面的状态,这是因为浏览器只能记下历史记录中的静态页面。

2.使用JavaScript作Ajax的引擎,JavaScript的兼容性和Debug本身就让人头大。

3.破坏多层的系统架构(前端直接访问数据库)。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<input type="text" id="data">
<div id="load"></div>
<script>
    var ajax={
        /*1.创建xmlhttprequest请求*/
        createXmlHttp:function(){
            //非ie浏览器
            if(window.XMLHttpRequest){
                xmlHttp=new XMLHttpRequest();
            }
            //ie浏览器
            if(window.ActiveXObject){
                try {
                    xmlHttp=new ActiveXObject('Microsoft.XMLHTTP');
                }catch (e){
                    try {
                        xmlHttp=new ActiveXObject('msxml2.XMLHTTP');
                    }catch (e){}
                }
            }
        },
        testAjax:function(){
            var data=document.getElementById("data").value;
            this.createXmlHttp();
            if(!xmlHttp){
                alert("创建xml对象异常");
                return false;
            }
            var url="json.json";
            /*2.打开链接,向服务请求*/
            xmlHttp.open("POST",url,true);
            xmlHttp.onreadystatechange=function(){
                if(xmlHttp.readyState==4){
                document.getElementById("load").innerHTML="数据正在加载......";
                    if(xmlHttp.status==200){
                        document.write(xmlHttp.responseText);
                    }
                }
            }
            //发送请求
            xmlHttp.send();
        }
    }
    ajax.testAjax();



    /* 如上所示,函数首先检查XMLHttpRequest的整体状态并且保证它已经完成(readyStatus=4),即数据已经发送完毕。然后根据服务器的设定询问请求状态,如果一切已经就绪(status=200),那么就执行下面需要的操作。
     对于XmlHttpRequest的两个方法,open和send,其中open方法指定了:
     a、向服务器提交数据的类型,即post还是get。
     b、请求的url地址和传递的参数。
     c、传输方式,false为同步,true为异步。默认为true。如果是异步通信方式(true),客户机就不等待服务器的响应;如果是同步方式(false),客户机就要等到服务器返回消息后才去执行其他操作。我们需要根据实际需要来指定同步方式,在某些页面中,可能会发出多个请求,甚至是有组织有计划有队形大规模的高强度的request,而后一个是会覆盖前一个的,这个时候当然要指定同步方式。
     Send方法用来发送请求。*/
</script>
</body>
</html>



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值