【Ajax】封装方法

目录

1、描述

2、原因分析

3、解决方案


描述:

代码优化:Ajax方法封装与使用


原因分析:

为了提高开发效率和代码可读性、可复用性和可维护性
试想如果不封装,那每次发出ajax请求都要写很多相同的代码,一个页面一般都有好几个请求,那相同的代码在一个页面要写好几次,不仅影响开发效率,还影响代码可维护性和可读性。而要是封装起来,把ajax请求中会变化的部分比如请求方式、url以及参数等等抽离出来,把需要重复写的代码封装起来,需要用的时候再调用并传入相应参数,代码可读性、可维护性等等和开发效率就会更高一点


解决方案:

js

function $FAjax(AOption){
    var xhr = new XMLHttpRequest();
    xhr.open(AOption.method, AOption.url, AOption.async);
    xhr.send();
    xhr.onreadystatechange = function (){
        if(xhr.readyState == 4){
            if(xhr.status == 200){
                AOption.success(xhr.responseText);
            }
        }
    };
    xhr.onerror = function (err){
        AOption.error(err);
    };
}

 html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>加载更多</title>
    <link rel="stylesheet" href="./css/index.css">
</head>
<body>
    <div class="newsbox">
        <input type="text" placeholder="请输入需要添加的内容" name="" id="myinput">
        <a id="more" class="more" href="javascript:;">点击添加</a>
    </div>
    <script src="./js/FQuery.js"></script>
</body>
</html>
<script>
    var myinput = document.querySelector('#myinput')
    $(".more").onclick = function (){
        var thevalue = myinput.value
        $FAjax({
            method: "GET", 
            url: 'http://localhost/php/index1.php?data='+thevalue, 
            async: true,
            success: function (res){
                console.log(res);
            },
            error: function (err){
                console.log(err);
            }
        });
    };
</script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值