搜索

查看: 3181|回复: 11

[JavaScript] Jquery使用原生AJAX方法请求数据

[复制链接]
发表于 2023-5-4 11:51:54 | 显示全部楼层 |阅读模式
Editor 2023-5-4 11:51:54 3181 11 看全部
目录
  • 1.原生ajax
  • 1.具体步骤
  • 2.get请求
  • 3.post请求
  • 4.封装方法
  • 2.jquery的ajax方法
    1.原生ajax
    1.具体步骤
    1.创建XMLHTTPRequest对象
    2.使用open方法设置和服务器的交互信息
    3.设置发送的数据,开始和服务器端交互
    4.注册事件
    5.更新界面

    2.get请求
    //步骤一:创建异步对象
    var ajax = new XMLHttpRequest();
    //步骤二:设置请求的url参数,参数一是请求的类型,参数二是请求的url,可以带参数,动态的传递参数starName到服务端
    ajax.open('get','getStar.php?starName='+name);
    //步骤三:发送请求
    ajax.send();
    //步骤四:注册事件 onreadystatechange 状态改变就会调用
    ajax.onreadystatechange = function () {
       if (ajax.readyState==4 &&ajax.status==200) {
        //步骤五 如果能够进到这个判断 说明 数据 完美的回来了,并且请求的页面是存在的
        console.log(ajax.responseText);//输入相应的内容
        }
    }

    3.post请求
    //创建异步对象  
    var xhr = new XMLHttpRequest();
    //设置请求的类型及url
    //post请求一定要添加请求头才行不然会报错
    xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded");
    xhr.open('post', '02.post.php' );
    //发送请求
    xhr.send('name=fox&age=18');
    xhr.onreadystatechange = function () {
        // 这步为判断服务器是否正确响应
      if (xhr.readyState == 4 && xhr.status == 200) {
        console.log(xhr.responseText);
      }
    };

    4.封装方法
    为了方便使用,封装一个方法
    function ajax_method(url,data,method,success) {
        // 异步对象
        var ajax = new XMLHttpRequest();
        // get 跟post  需要分别写不同的代码
        if (method=='get') {
            // get请求
            if (data) {
                // 如果有值
                url+='?';
                url+=data;
            }else{
            }
            // 设置 方法 以及 url
            ajax.open(method,url);
            // send即可
            ajax.send();
        }else{
            // post请求
            // post请求 url 是不需要改变
            ajax.open(method,url);
            // 需要设置请求报文
            ajax.setRequestHeader("Content-type","application/x-www-form-urlencoded");
            // 判断data send发送数据
            if (data) {
                // 如果有值 从send发送
                ajax.send(data);
            }else{
                // 木有值 直接发送即可
                ajax.send();
            }
        }
        // 注册事件
        ajax.onreadystatechange = function () {
            // 在事件中 获取数据 并修改界面显示
            if (ajax.readyState==4&&ajax.status==200) {
                // console.log(ajax.responseText);
                // 将 数据 让 外面可以使用
                // return ajax.responseText;
                // 当 onreadystatechange 调用时 说明 数据回来了
                // ajax.responseText;
                // 如果说 外面可以传入一个 function 作为参数 success
                success(ajax.responseText);
            }
        }
    }

    2.jquery的ajax方法
    login.addEventListener('click', () => {
            // if (username.value == uname && password.value == upw) {
            $.ajax({
                type: 'post',                                // 请求方式
                url: 'http://127.0.0.1:3007/api/login',                // 路径
                // contentType: "application/json",
                dataType: 'json',                // 这里是指定了参数的类型
                data: {
                    'username': username.value,
                    'password': password.value
                }
                ,
                success: function (res) {
                    console.log(res);
                    // var yanzheng = { status: 0, message: '登录成功!' }
                    if (res.status == 0) {
                        alert('登录成功');
                        self.location.href = "index.html?id=" + res.id;
                    }
                    else {
                        alert('请输入正确的用户名或密码')
                    }
                }
            })
        })
    参数
    options
    类型:Object
    可选。AJAX 请求设置。所有选项都是可选的。
    async
    类型:Boolean
    默认值: true。默认设置下,所有请求均为异步请求。如果需要发送同步请求,请将此选项设置为 false。
    注意,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。
    beforeSend(XHR)
    类型:Function
    发送请求前可修改 XMLHttpRequest 对象的函数,如添加自定义 HTTP 头。
    XMLHttpRequest 对象是唯一的参数。
    这是一个 Ajax 事件。如果返回 false 可以取消本次 ajax 请求。
    cache
    类型:Boolean
    默认值: true,dataType 为 script 和 jsonp 时默认为 false。设置为 false 将不缓存此页面。
    jQuery 1.2 新功能。
    contentType
    类型:String
    默认值: “application/x-www-form-urlencoded”。发送信息至服务器时内容编码类型。
    默认值适合大多数情况。如果你明确地传递了一个 content-type 给 $.ajax() 那么它必定会发送给服务器(即使没有数据要发送)。
    context
    类型:Object
    这个对象用于设置 Ajax 相关回调函数的上下文。也就是说,让回调函数内 this 指向这个对象(如果不设定这个参数,那么 this 就指向调用本次 AJAX 请求时传递的 options 参数)。比如指定一个 DOM 元素作为 context 参数,这样就设置了 success 回调函数的上下文为这个 DOM 元素。
    就像这样:
    $.ajax({ url: "test.html", context: document.body, success: function(){
            $(this).addClass("done");
          }});
    data
    类型:String
    发送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData 选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2'。
    dataFilter
    类型:Function
    给 Ajax 返回的原始数据的进行预处理的函数。提供 data 和 type 两个参数:data 是 Ajax 返回的原始数据,type 是调用 jQuery.ajax 时提供的 dataType 参数。函数返回的值将由 jQuery 进一步处理。
    dataType
    类型:String
    预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML。在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script 则会执行这个脚本。随后服务器端返回的数据会根据这个值解析后,传递给回调函数。可用值:
  • “xml”: 返回 XML 文档,可用 jQuery 处理。
  • “html”: 返回纯文本 HTML 信息;包含的 script标签会在插入 dom 时执行。
  • “script”: 返回纯文本 JavaScript 代码。不会自动缓存结果。除非设置了 "cache"参数。注意:在远程请求时(不在同一个域下),所有 POST 请求都将转为 GET 请求。(因为将使用 DOM 的script标签来加载)
  • “json”: 返回 JSON 数据 。
  • “jsonp”: JSONP 格式。使用 JSONP形式调用函数时,如 “myurl?callback=?” jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。
  • “text”: 返回纯文本字符串
    error
    类型:Function
    默认值: 自动判断 (xml 或 html)。请求失败时调用此函数。
    有以下三个参数:XMLHttpRequest 对象、错误信息、(可选)捕获的异常对象。
    如果发生了错误,错误信息(第二个参数)除了得到 null 之外,还可能是 "timeout", "error", "notmodified" 和 "parsererror"。
    这是一个 Ajax 事件。
    global
    类型:Boolean
    是否触发全局 AJAX 事件。默认值: true。设置为 false 将不会触发全局 AJAX 事件,如 ajaxStart 或 ajaxStop 可用于控制不同的 Ajax 事件。
    jsonp
    类型:String
    在一个 jsonp 请求中重写回调函数的名字。这个值用来替代在 “callback=?” 这种 GET 或 POST 请求中 URL 参数里的 “callback” 部分,比如 {jsonp:‘onJsonPLoad’} 会导致将 “onJsonPLoad=?” 传给服务器。
    success
    类型:Function
    请求成功后的回调函数。
    参数:由服务器返回,并根据 dataType 参数进行处理后的数据;描述状态的字符串。
    这是一个 Ajax 事件。
    traditional
    类型:Boolean
    如果你想要用传统的方式来序列化数据,那么就设置为 true。请参考工具分类下面的 jQuery.param 方法。
    timeout
    类型:Number
    设置请求超时时间(毫秒)。此设置将覆盖全局设置。
    type
    类型:String
    默认值: “GET”)。请求方式 (“POST” 或 “GET”), 默认为 “GET”。注意:其它 HTTP 请求方法,如 PUT 和 DELETE 也可以使用,但仅部分浏览器支持。
    url
    类型:String
    默认值: 当前页地址。发送请求的地址。
    error
    在请求出错时调用。传入 XMLHttpRequest 对象,描述错误类型的字符串以及一个异常对象(如果有的话)
    dataFilter
    在请求成功之后调用。传入返回的数据以及 “dataType” 参数的值。并且必须返回新的数据(可能是处理过的)传递给 success 回调函数。
    success
    当请求之后调用。传入返回后的数据,以及包含成功代码的字符串。
    complete
    当请求完成之后调用这个函数,无论成功或失败。传入 XMLHttpRequest 对象,以及一个包含成功或错误代码的字符串。
    到此这篇关于Jquery使用原生AJAX方法请求数据的文章就介绍到这了,更多相关Jquery AJAX方法内容请搜索知鸟论坛以前的文章或继续浏览下面的相关文章希望大家以后多多支持知鸟论坛!
  • 发表于 2023-6-28 23:22:19 | 显示全部楼层
    普通人物怨 2023-6-28 23:22:19 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    发表于 2023-6-29 11:49:23 | 显示全部楼层
    当当当当裤裆坦 2023-6-29 11:49:23 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    发表于 2023-6-29 16:58:58 | 显示全部楼层
    音乐之家1 2023-6-29 16:58:58 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    发表于 2023-6-29 17:40:34 | 显示全部楼层
    执着等待等wc 2023-6-29 17:40:34 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    发表于 2023-6-29 19:13:21 | 显示全部楼层
    素色流年783 2023-6-29 19:13:21 看全部
    楼主,大恩不言谢了!知鸟论坛是最棒的!
    发表于 2023-6-29 23:32:26 | 显示全部楼层
    麻辣鸡翅 2023-6-29 23:32:26 看全部
    我看不错噢 谢谢楼主!知鸟论坛越来越好!
    发表于 2023-6-30 05:47:04 | 显示全部楼层
    无人岛屿颈 2023-6-30 05:47:04 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    发表于 2023-6-30 09:53:26 | 显示全部楼层
    术数古籍专卖疤 2023-6-30 09:53:26 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    发表于 2023-6-30 19:47:18 | 显示全部楼层
    十二音阶囤 2023-6-30 19:47:18 看全部
    楼主,大恩不言谢了!知鸟论坛是最棒的!
    • 您可能感兴趣
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则 返回列表

    RSS订阅| 小黑屋| 知鸟论坛 |网站地图
    本站资源来自互联网用户收集发布,如有侵权请邮件联系处理。 联系邮箱E-mail:zniao@foxmail.com
    快速回复 返回顶部 返回列表