IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 重写post和get方法 -> 正文阅读

[JavaScript知识库]重写post和get方法

一、重写jQuery的get请求

对ajax中的get方法进行重写

1.首先得知道get请求需要传递的参数

? url,

? data

? header

? success/error

2.其次知道在get方法中传递这些参数的作用

let xhr = new XMLHttpRequest()

? url表示请求的地址

? data:表示传递进去的数据,get请求的数据是放在url中,需要给url做一个与data的拼接

? url = url+'?'+Qs.stringify(data)

xhr.open('GET',url)

? header:表示请求的头部,包括获取的令牌,在open和send之间

for(var i in headers){
let v = header[i];
}

xhr.send()

success:表示请求成功之后的一个回调

success.call(this,resp)

3.然后再将全部代码写出

let jQuery = {};
(function() {
    $.get = function({
        url,
        data = {},
        headers = {},
        success
    }) {
        let xhr = new XMLHttpRequest();
        url = url + "?" + Qs.stringify(data);
        xhr.ope n('GET', url);
        //对头部信息进行一个遍历
        for (let i in headers) {
            let k = hearders[i];
            xhr.setRequestHeaders(i, k);
        }
        xhr.send();
        //请求成功后,成功的回调函数
        xhr.onreadystatechange = function() {
            if (xhr.readyState === 4 && xhr.status === 200) {
                //将返回的结果进行转换,将其转换成对象
                let reps = Json.parse(xhr.response);
                success.call(this, reps);
            }

        }
    }
})(jQuery);

测试的HTML页面如下

<script>
    let url = "当前测试的接口";
    let token =
        "xxxx";
    jQuery.get({
        url,
        headers: {
            "Authorization": token
        },
        success: function(res) {
            console.log('结果', res);
        }
    })
</script>

二、重写jQuery中post请求

对jQuery中的post请求进行重写

我们知道,在post请求中,数据是存放在请求体中,下面是我写的重写的post请求,但是感觉不太对,希望各位批评指正

// 重写post请求
let jQuery = {};
(function($) {
    $.post = function({
        url,
        // params = {},
        data = {},
        headers = {},

        success

    }) {
        // 初始化xhr
        let xhr = new XMLHttpRequest();
        // 初始化请求头

        xhr.open('POST', url);


        for (let k in headers) {
            let v = headers[k];
            xhr.setRequestHeader(k, v);
        }
        // 初始化请求体
        // xhr.setRequestHeader("Authorization",token);
        xhr.send(JSON.stringify(data));
        // 监听响应
        xhr.onreadystatechange = function() {
            if (this.readyState === 4 && this.status === 200) {
                let resp = JSON.parse(this.response);
                success.call(this, resp);
            }            
            }
        }


    }
})(jQuery);

html代码:

<script>
    let url = "测试接口";
    let data = {
        id: 100,
        name: 'zs',
        introduce: 'beautiful',
        url,
        status: 'sss'
    }
    let json = 'application/x-www-form-urlencoded';
    let token = "xxx"
    jQuery.post({
        url,
        data,
        headers: {
            "Authorization": token,
            'Content-Type': json
        },
        success: function(res) {
            console.log(data);
            console.log("结果", res);
        }

    })
</script>

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-09-18 10:03:42  更:2021-09-18 10:04:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/18 21:38:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码