关于Ajax的封装详解

 更新时间:2023年05月17日 10:31:49   作者:独立寒秋-  
这篇文章主要介绍了关于Ajax的封装详解,ajax用于浏览器与服务器之间使用异步数据传输(HTTP 请求),做到局部请求以实现局部刷新,本篇讲解ajax的封装,需要的朋友可以参考下

Ajax的封装

一个免费的测试接口

https://api.apiopen.top/getJoke

一、最简单的原生Ajax封装

  • 先看下效果

在这里插入图片描述

  • 具体代码
<body>
    <div class="box">
        <button id="btn">来段数据</button><br>
    <textarea  id="text" ></textarea>
    </div>
    <script>
        const btn = document.getElementById("btn");
        const txt = document.getElementById("text");
        btn.onclick = function(){
             getAjax('get','https://api.apiopen.top/getJoke',function(res){
                let narr=[];
                for(let i=0;i<res.length;i++){
                    narr.push('\n'+(i+1)+'.'+res[i].text)
                    console.log(res[i].text);
                    text.innerHTML=narr;
                }
             });
        }
        function getAjax(method,url,callback){
            const xhr =  new XMLHttpRequest();
            xhr.open(method,url);
            xhr.send();
            xhr.onreadystatechange = function(){
                if(xhr.readyState === 4){
                    if(xhr.status>=200 && xhr.status<300){
                        const res = JSON.parse(xhr.response);
                        callback(res.result);
                    }
                }
            }
        }
    </script>

二、使用promise函数封装

Promise是ES6引入的异步编程的新解决方案,语法上Promise是一个构造函数,用来封装异步操作并可以获取其成功或者失败的回调结果。

  • 通过promise实例化的对象可以接受一个参数,参数类型为函数,该函数的两个参数是resolve和reject,
  • 在请求到数据后可以通过resolve、resolve函数来改变Promise对象的状态
  • resolve表示成功,resolve表示失败
  • 成功或者失败都可以调用Promise对象的then方法
  • then接收两个参数,两个参数都是函数类型
  • 成功的形参为value,失败的形参为reason
  • value就是resolve方法里的返回结果
<script>
    const btn = document.getElementById("btn");
    btn.onclick = function(){
        grtAjax('get','https://api.apiopen.top/getJoke',function(res){
            console.log(res);
        });
    }
    function grtAjax(method,url,callback){
        const p = new Promise((resolve,reject)=>{
            const xhr = new XMLHttpRequest();
            xhr.open(method,url);
            xhr.send();
            xhr.onreadystatechange = function(){
                if(xhr.readyState == 4){
                    if(xhr.status >= 200 && xhr.status < 300){
                        resolve(xhr.response);
                    }else{
                        reject(xhr.status);
                    }
                }
            }
        });
        p.then(function(value){
            const res = JSON.parse(value);
            callback(res.result)
        },function(reason){
        console.error(reason);
        })
    }
</script>

在这里插入图片描述

三、promise配合async和await使用

async

  • async和await两种语法结合可以让异步代码像同步代码一样
  • async函数的返回值为promise对象
  • 该promise对象的结果是由async函数执行的返回值决定的
  • 只要返回值的类型不是一个promise类型的对象则async函数的返回结果就是一个成功的promise对象
  • 返回值的类型不是一个promise类型的对象则跟promise对象的状态有关revolve或者reject或者抛出异常

await

  • await右侧的表达式一般为promise对象,但也可以是其他的值
  • 如果是promise对象,await返回的是promise成功的值
  • 如果是其他的值,直接将此值作为await的返回值
  • await必须写在async函数中,但是async函数中可以没有await
  • 如果await的promise状态是失败的,就会抛出异常,需要通过try…catch捕获处理

在这里插入图片描述

<body>
    <button>请求数据</button>
    <script>
        const btn = document.querySelector('button');
        function sendAjax(method,url){
            return new Promise((resolve,reject)=>{  
                const xhr = new XMLHttpRequest();
                xhr.responseType = 'json';
                xhr.open(method,url);
                xhr.send();
                xhr.onreadystatechange = function(){
                    if(xhr.readyState === 4){
                        if(xhr.status >=200 && xhr.status<300){
                            resolve(xhr.response);
                        }else{
                            reject(xhr.status);
                        }
                    }
                }
            })
        }
        btn.addEventListener('click',async function(){
            let result = await sendAjax('get','https://api.apiopen.top/getJoke');
            console.log(result);
        })
    </script>
</body>

四、使用axios工具库直接发送Ajax

Axios 是一个基于 promise 网络请求库,作用于node.js 和浏览器中。 它是 isomorphic 的(即同一套代码可以运行在浏览器和node.js中)。在服务端它使用原生 node.js http 模块, 而在客户端 (浏览端) 则使用 XMLHttpRequests。

  • 这里使用了vue-cli搭建了一个vue项目并下载了 axios

post

在这里插入图片描述

get

在这里插入图片描述

<template>
<div>
        <button @click="post">直接发送POST</button>
        <button @click="get">直接发送GET</button>
  </div>
</template>
<script>
export default {
  data(){
    return{}
  },
  methods:{
    async get(){
      const {data:res} = await this.$axios.get('https://api.apiopen.top/getJoke',{
        params:{id:1}
      });
      console.log(res);
    },
     post(){
      this.$axios.post('https://api.apiopen.top/getJoke',{name:'yxj',gender:'男'})
      .then((res)=>{
        console.log(res.data.result);
      });
    }
  }
}
</script>

到此这篇关于关于Ajax的封装详解的文章就介绍到这了,更多相关Ajax的封装内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅谈Ajax和JavaScript的区别

    浅谈Ajax和JavaScript的区别

    下面小编就为大家带来一篇浅谈Ajax和JavaScript的区别。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-07-07
  • ajax异步加载图片实例分析

    ajax异步加载图片实例分析

    这篇文章主要介绍了ajax异步加载图片的方法,结合实例形式较为详细的分析了ajax图片异步加载的原理与相关实现技巧,需要的朋友可以参考下
    2016-02-02
  • ajax详解_动力节点Java学院整理

    ajax详解_动力节点Java学院整理

    这篇文章主要介绍了ajax详解,详细的介绍了Ajax 简史以及 基本用法,有兴趣的可以了解一下
    2017-07-07
  • 解决ajax跨域请求数据cookie丢失问题

    解决ajax跨域请求数据cookie丢失问题

    本文主要是从前端jquery和服务端php为例,分别使用实例解决ajax跨域请求数据cookie丢失问题,推荐给有相同需求的小伙伴们。
    2015-03-03
  • AJAX简单异步通信实例分析

    AJAX简单异步通信实例分析

    这篇文章主要介绍了AJAX简单异步通信,实例分析了Ajax异步通信的技巧与相关注意事项,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • Ajax实现注册并选择头像后上传功能

    Ajax实现注册并选择头像后上传功能

    这篇文章主要介绍了Ajax实现注册并选择头像后上传功能,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • PHP匹配连续的数字或字母的正则表达式

    PHP匹配连续的数字或字母的正则表达式

    PHP匹配连续的数字或字母的正则表达式,需要的朋友可以参考下。
    2011-05-05
  • ajax实现无刷新上传文件功能

    ajax实现无刷新上传文件功能

    这篇文章主要为大家详细介绍了ajax实现无刷新上传文件功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • ajax传送参数含有特殊字符的快速解决方法

    ajax传送参数含有特殊字符的快速解决方法

    下面小编就为大家带来一篇ajax传送参数含有特殊字符的快速解决方法。希望对大家有所帮助,一起跟随小编过来看看吧
    2016-04-04
  • 通过Ajax两种方式讲解Struts2接收数组表单的方法

    通过Ajax两种方式讲解Struts2接收数组表单的方法

    使用struts2表单传值,可以传一个或者是作为一个对象的各个属性传,都非常灵活便捷。但是如果我们需要传一个数组并希望struts正确接收,该怎么处理呢?接下来,通过本文给大家介绍通过Ajax两种方式讲解Struts2接收数组表单的方法,需要的朋友可以参考下
    2015-10-10

最新评论