博客列表 >Ajax - GET 与Ajax - POST 的区别 --2019-07-16 22:22

Ajax - GET 与Ajax - POST 的区别 --2019-07-16 22:22

烦帅不防晒
烦帅不防晒原创
2019年07月22日 00:27:54925浏览

页面向服务器请求数据有两种方式:GET请求  与 POST请求

GET请求会把数据之间放在url上进行传输,保密性差

POST请求会把数据隐藏起来传输,且传回要用JSON转换格式,保密性强

一、GET请求:

62{O28BT3S$6BT`%0J%3_X9.png

实例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Ajax-GET</title>
</head>
<body>
    <label for="user-id">请输入ID</label>
    <input type="text" id="user-id" name="user_id" autofocus>
    <p id="tips"></p>

<script>
    var input= document.getElementById('user-id');
    var tips = document.getElementById('tips');
     // 1、创建、请求对象
    var request=new XMLHttpRequest();
    input.addEventListener('keypress',getUserInfo,false);
    function getUserInfo(ev) {
        if (ev.key === 'Enter'){
           switch (true) {
               case input.value.length === 0:
                   tips.innerHTML = '<span style="color:red">不能为空</span>';
                   return false;
               case isNaN(input.value):
                   tips.innerHTML = '<span style="color:red">必须是整数</span>';
                   return false;
               default:
                   // 2.监听:成功回调
                   request.addEventListener('readystatechange', successCallback, false);
                   // 3.设置请求参数(请求类型,请求服务器上的就脚本程序,是否是异步)
                    var data =encodeURIComponent( input.value);//进行编码处理
                   request.open('GET', 'php/user_info.php?user_id='+data, true);
                   // 4. 发送,异步请求
                   request.send(null);
           }
        }
        function successCallback(ev) {
            if (request.readyState === 4) {
                tips.innerHTML=request.responseText
            }
        }
        input.addEventListener('input',function (ev) {
            tips.innerHTML = null;
        },false);
    }

运行实例 »

点击 "运行实例" 按钮查看在线实例

2.POST请求

4~HMW)BA}MD_U%@A00S9BMD.png

实例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Ajax-POSE</title>
</head>
<body>
<h2>用户登录</h2>
<form action="" name="login">
    <p>
        <label for="username">用户:</label>
        <input type="text" name="username" id="username" placeholder="UserName">
    </p>
    <p>
        <label for="email">邮箱:</label>
        <input type="text" name="email" id="email" placeholder="example@email.com">
    </p>
    <p>
        <label for="password">密码:</label>
        <input type="password" name="password" id="password" placeholder="******">
    </p>
    <p>
        <label for="remember">记住我:</label>
        <select name="remember" id="remember">
            <option value="1" name="day" selected>一天</option>
            <option value="7" name="week">一星期</option>
            <option value="30" name="month">一个月</option>
        </select>
    </p>
    <p>
        <button type="button" name="submit">提交</button>
    </p>
</form>

<script>
    // 1.获取表表单元素
    var login = document.forms.namedItem('login');
    var btn = login.submit;
    var request = new XMLHttpRequest();
      // 2.对表单内容进行验证
    login.username.addEventListener('blur',isEmpty,false);
    login.email.addEventListener('blur',isEmpty,false);
    login.password.addEventListener('blur',isEmpty,false);

    function isEmpty(ev) {
        if (ev.target.value.length === 0){
           // 1.创建非空验证的提示信息
            if (ev.target.nextElementSibling === null){
                var tips = document.createElement('span');
                tips.style.color='red';

                switch (ev.target.name) {
                    case 'username':
                    tips.innerText = '用户名不能为空';
                    break;
                    case 'email':
                        tips.innerText = '邮箱不能为空';
                    break;
                    case 'password':
                        tips.innerText = '密码不能为空';
                    break;
                    default:
                        tips.innerText = '未知错误';
                }
                ev.target.parentNode.appendChild(tips);
                // 锁定焦点
                ev.target.focus();
            }
        }
    }
    //3. 移除提示信息
    login.username.addEventListener('input',clearTips,false);
    login.email.addEventListener('input',clearTips,false);
    login.password.addEventListener('input',clearTips,false);
    function clearTips(ev) {
        var tips = ev.target.nextElementSibling;
        if (tips !== null) {
            tips.parentNode.removeChild(tips);
        }
    }
    // 4.Ajax 验证
    btn.addEventListener('click',check,false);

    function check(ev) {
        var username = login.username.value;
        var email = login.email.value;
        var password=login.password.value;
        var remember=login.remember.value;

        if (username.length === 0 || email.length === 0 || password.length === 0){
            btn.removeEventListener('click',check,false);
            // 事件模拟
            var blurEvent = new Event('blur');
            login.username.dispatchEvent(blurEvent);
            return false;
        }
        // 监听成功回调
        request.addEventListener('readystatechange',successCallback,false);

        // 设置请求参数
        request.open('POST','php/check.php',true);

        // 因为是POST,设置请求头
        request.setRequestHeader('content-type','application/x-www-form-urlencoded;charset=utf-8');

        // 发送 异步请求
        var data = 'username='+username+'&email='+email+'&password='+password+'&remember='+remember;
        request.send(data);
    }

    function successCallback(ev) {
        if (request.readyState === 4) {
            console.log(request.responseText);
        }

    }
</script>
</body>
</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例


声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议