博客列表 >post请求下的 js原生ajax 与 jquery ajax 2018-4-9

post请求下的 js原生ajax 与 jquery ajax 2018-4-9

一片叶
一片叶原创
2018年04月10日 18:34:48730浏览

js原生与jq下的ajax效果一样.如下:

2018-04-10_18-13-56.gif

js原生代码

<div>
    <fieldset >
      <legend>用户登录</legend>
      <p>邮件地址: <input type="email" name="" id="email" value=""></p>
      <p>用户密码: <input type="password" id="password" value=""></p>
      <button id="btn">登录</button>
      <span id="tips"></span>
    </fieldset>
  </div>
  <script>
    // 给按钮添加点击事件
    document.getElementById("btn").addEventListener('click',lond);
    // 回调函数lond
    function lond(){
      // 获取邮箱和密码并进行拼接
      var email = document.getElementById('email').value;
      var password = document.getElementById('password').value;
      var data = 'email='+email+'&password='+password;
      // 创建xhr对象
      var xml = new XMLHttpRequest();
      xml.open('post','api/user.php?m=login',true);
      xml.onload = function(){
        if(this.status == 200){
            console.log(this.responseText);
          if(this.responseText == 1){
            document.getElementById("tips").innerHTML = "正在跳转中";
            // 这里是ES6中的箭头函数,与setTimeout(function(){},)相同
            setTimeout(() => {
              location.href = './api/index.php';
            }, 2000);
          }else {
            document.getElementById("tips").innerHTML = "邮箱或密码错误";
            document.getElementById("email").focus();
            setTimeout(() => {
              document.getElementById("tips").innerHTML='';
            }, 2000);
          }
        }
      }
      xml.setRequestHeader('Content-Type','application/x-www-form-urlencoded');//这里可有可无
      xml.send(data);
    }
  
  </script>

jq下ajax

<body>
    <fieldset>
        <legend>用户登录</legend>
        <p>
          <label for="email">邮箱:</label>
          <input type="email" name="email" id="email">
        </p>
        <p>
          <label for="password">密码:</label>
          <input type="password" name="password" id="password">
        </p>
        <p>
          <button id="btn">登录</button>
          <span id="tips" style="font-size:1.2em;font-weight: bolder;color:red"></span>
        </p>
        
        <script>
        $('#btn').click(function(){
         //创建post请求方式的xml对象 $.post(必须-将请求发送到那个url,可选-连同请求发送到服务器的数据,可选-当请求发送成功后的回调函数,可选-预期服务器响应的数据类型)
          $.post(
            'api/user.php?m=login',
            {
            "email": $('#email').val(),
            "password": $('#password').val()
            },
            function(data){
            if (data == '1') {
              $('#tips').text('登录成功,正在跳转中...')
              setTimeout(function(){
                location.href = 'api/index.php'
              },2000)
            } else {
              $('#tips').text('邮箱或密码错误,请重新输入...')
              $('#email').focus()
              setTimeout("$('#tips').empty()",2000)
              }
              }, 
              'json')
        })
        </script>
</body>

dllhost_2018-04-10_18-35-37.png

jq简化了原生js的写法.对应关系并没有改变

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