zoukankan      html  css  js  c++  java
  • 总结Ajax的一些细节

    Ajax的总结

    • 主要从Ajax是什么?可以用来干什么?基本要素,优缺点,执行过程,跨域的解决方案等几方面来解释。

    Ajax是什么?

    • Ajax主要用来实现客户端与服务器端的异步通信效果,实现页面的局部刷新,早期的浏览器并不能原生支持ajax,可以使用隐藏帧(iframe)方式变相实现异步刷新,使用ajax原生发送请求主要通过XMLHttpRequest对象实现异步通信的效果。

    Ajax的工作原理

    • 简单来说通过XmlHttpRequest对象来向服务器发送异步请求,从服务器获得数据,然后利用javascript来操作DOm而更新页面,这其中最关键的一步就是从服务器获得请求数据

    Ajax要素

    • 实现原生Ajax的核心就是 XMLHttpRequest
    • Ajax请求的重点内容:
      • 请求方式:get/post
        1、get一般用来进行查询操作,url地址有长度限制,请求的参数都暴露在url地址当中,如果传递中文参数,需要自己进行编码操作,安全性较低。
        2、post请求方式主要用来提交数据,没有数据长度的限制,提交的数据内容存在于http请求体中,数据不会暴漏在url地址中。
      • 响应内容:xhr.responseText;(重点)xhr.responseXML
    • 原理:利用script标签向外发出请求不会被拒绝
    • ajax的优缺点
      • 优点:可以使得页面不重载全部内容的情况下加载局部内容,降低数据传输量,避免用户不断刷新或者跳转页面,提高用户体验。
      • 缺点:
        1、ajax不支持浏览器back按钮。
        2、安全问题 AJAX暴露了与服务器交互的细节。
        3、对搜索引擎的支持比较弱。
        4、破坏了程序的异常机制。

    Ajax的异步刷新

    • iframe 在一个页面内部嵌入一个子页面
      • name属性表示iframe的名称,用于区分不同的iframe
      • iframe属性frameborder表示子页面的边框
      • width和height分别表示子页面的宽高
      • src属性表示嵌入子页面的url地址
    • 可以通过表单的target属性指向iframe的name属性值,表示响应内容在子页面刷新
         <div id="info"></div>
        <form action="./inner.php" method="post" target="abc">
            用户名:<input type="text" name="username">
            密  码:<input type="password" name="password">
            <input type="submit" value="提交">
        </form>
        <iframe width="0" height="0" frameborder="0" name="abc"></iframe>
    
        <?php 
    
        $uname = $_POST['username'];
        $pw = $_POST['password'];
        // js中的parent表示父级页面
        if($uname == 'admin' && $pw == '123'){
            echo '<script> parent.document.getElementById("info").innerHTML = "登录成功";</script>';
        }else{
            echo '<script> parent.document.getElementById("info").innerHTML = "用户名或者密码错误";</script>';
        }
            
     ?>
    

    ajax的基本操作步骤

    • 执行过程
           // 1、创建XMLHttpRequest对象
                var xhr = new XMLHttpRequest();
                // 2、配置发送参数
                xhr.open('get','./data.php');
                // 3、执行发送动作
                xhr.send(null);
                // 4、处理响应
                xhr.onreadystatechange = function(){
                    if(xhr.status == 200){
                        if(xhr.readyState == 4){
                            // 在这里才可以获取服务器返回的数据
                            var result = xhr.responseText;
                            if(result === '1'){
                                var info = document.getElementById('info');
                                info.innerHTML = '服务器数据已经返回';
                            }
                        }
                    }
                }
    
    • 封装
           function myajax(type,url,param,callback){
        // 1、创建xhr对象
        var xhr = null;
        if(window.XMLHttpRequest){
            // 标准写法
            xhr = new XMLHttpRequest();
        }else{
            // IE的写法
            xhr = new ActiveXObject('Microsoft.XMLHTTP');
        }
        // 2、准备发送参数
        if(type == 'get'){
            // 处理get请求参数,并且进行编码
            url += '?' + encodeURI(param);
        }
        xhr.open(type,url);
        // 3、执行发送动作
        var data = null;
        if(type == 'post'){
            // 如果是post提交,那么就把参数传递给send
            data = param;
            // post提交必须设置请求头
            xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
        }
        xhr.send(data);
        // 4、处理响应(指定回调函数)
        // 下面的回调函数什么时候执行?不确定的
        xhr.onreadystatechange = function(){
            // 判断响应的状态
            if(xhr.status == 200 && xhr.readyState == 4){
                // 获取响应数据
                var result = xhr.responseText;
                // 调用回调函数
                callback(result);
            }
        }
    }
    

    ajax的跨域解决方案

    jsonp,是一种解决方案,默认是get请求,如果有需求是post请求的话,可以使用CORS跨域资源共享,客服了ajax只能同源请求的限制,实现CORS通信的关键是服务器,只要服务器实现了CORS接口,就可以跨域通信。

    浏览器将CORS请求分为俩大类,简单强求和非简单请求

    ajax的优点和缺点

    • 优点
      可以实现异步通信的效果,实现局部刷新,带来更好的用户体验,按需获取数据,节约带宽资源。
    • 缺点
      ajax不支持浏览器的back按钮。
      安全问题(暴露了与服务器交互的细节)。
      破坏了程序的异常机制。
      对搜索引擎的支持性比较弱。
  • 相关阅读:
    [Angular] @ContentChild and ngAfterContentInit
    [Angular] Content Projection with ng-content
    [ES2016] Check if an array contains an item using Array.prototype.includes
    [Ramda] Handle Errors in Ramda Pipelines with tryCatch
    [React Native] Installing and Linking Modules with Native Code in React Native
    [Ramda] Refactor to Point Free Functions with Ramda using compose and converge
    [React Native] Writing Platform-Specific Components for iOS and Android in React Native
    [Redux] Avoid action type naming conflicts
    paip.索引优化---sql distict—order by 法
    DL,DT,DD,比传统table更语义,解析更快的table列表方式
  • 原文地址:https://www.cnblogs.com/lml-lml/p/6932107.html
Copyright © 2011-2022 走看看