AJAX

作者: 山门龙龙 | 来源:发表于2017-07-12 18:08 被阅读0次

1.ajax 是什么?有什么作用?

  • ajax是一种技术方案,它通过浏览器提供的XMLHttpRequest对象,使得浏览器可以发送http请求和接收http响应
  • 可以在不刷新页面的情况下,和后端交互数据。

2.前后端开发联调需要注意哪些事情?后端接口完成前如何 mock 数据?

  • 约定数据。数据在传输中的格式,数据的类型。
  • 约定接口。约定请求的格式,响应的格式。
  • 按照约定编写接口文档。

1.在node.js环境下使用npm下载server-mock(淘宝npm镜像地址可以大大加快下载速度)
2.按照接口文档编写假数据进行测试。

3.点击按钮,使用 ajax 获取数据,如何在数据到来之前防止重复点击?

伪代码如下:

var btnStatus = true;
var btn = document.querySelector('#btn');
btn.addEventListener('click',function () {
    if(btnStatus === false){
          return;                   // 判断btnStatus状态, 为真才执行,为假不执行
}
    var xhr = new XMLHttpRequest();
    xhr.onreadystatechange = function(){
    btnStatus = true;         //xhr状态发生改变时,btnStatus状态为真,此时点击有效。
    .........
}
    xhr.open('get',url,true);
    xhr.send();
    btnStatus = false;       //发送请求之后,锁死btn点击状态,只有xhr状态发生改变点击才有效果。
});

4.实现加载更多的功能,效果范例307,后端在本地使用server-mock来模拟数据

前端代码:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<style>
    body{
        margin: 0;
        padding: 0;
    }

    ul{
        padding: 0;
        width: 98%;
        margin: 0 auto;
    }

    ul li{
        margin-top: 10px;
        list-style: none;
        padding: 10px 20px;
        border: 1px solid #ccc;
        cursor: pointer;
    }

    ul li:hover{
        background: green;
    }

    button{
        display: block;
        outline: none;
        padding: 10px 7px;
        border: 1px solid #E27272;
        border-radius: 3px;
        color: #E27272;
        font-size: 18px;
        margin: 50px auto;
        background: #ffffff;
    }
</style>
<body>
<ul>
    <li>内容1</li>
    <li>内容2</li>
</ul>
<button>加载更多</button>
<script>
    var ul = document.querySelector('ul');
    var btn = document.querySelector('button');
    var btnStatus = true;
    var liIndex = 3;
    btn.addEventListener('click',function () {
        if(btnStatus === false){
            return;
        }
        var xhr = new XMLHttpRequest();
        xhr.onreadystatechange = function () {
            btnStatus = true;
            if(xhr.readyState === 4){
                if(xhr.status === 200 || xhr.status === 304){
                    var results = JSON.parse(xhr.responseText);
                    console.log(results);
                    var frag = document.createDocumentFragment();
                    for(var i=0;i<results.length;i++){
                        var li = document.createElement('li');
                        li.innerText = results[i];
                        frag.appendChild(li);
                    }
                    ul.appendChild(frag);
                    liIndex += 5;
                }else{
                    console.log('出错了');
                }
            }
        }
        xhr.open('get','/loadMore?index='+liIndex+'&length=5',true);
        xhr.send();
        btnStatus = false;
    })
</script>
</body>
</html>

后端代码:

router.get('/loadMore',function (req,res) {
    var index = req.query.index;
    var length = req.query.length;
    var data = [];
    for(var i=0;i<length;i++){
        data.push('内容' + (parseInt(index) + i));
    }
    setTimeout(function(){
        res.send(data);
    },1500)
});

相关文章

  • AJAX

    主要内容: ajax 是什么、原生ajax 写法和jQuery ajax写法。 AJAX 是什么 ajax,即As...

  • JavaScript进阶知识点--AJAX及JSON

    AJAX 关于 AJAX 什么是 AJAX AJAX 的全称是 Asynchronous JavaScript a...

  • HTML5权威指南 | 第五部分 高级功能

    三十二、使用AJAX(上) Ajax起步: 使用Ajax事件: Ajax请求的错误处理: 中止Ajax请求: 三十...

  • ajax学习笔记

    Ajax学习笔记 Ajax简介 1. Ajax是什么? Ajax : Asynochronous javascri...

  • AJAX

    一、简介 AJAX菜鸟教程 什么是 AJAX ? AJAX = 异步 JavaScript 和 XML。 AJAX...

  • js之AJAX复习

    异步交互和同步交互 什么是Ajax? Ajax的工作原理。 Ajax包含的技术: Ajax的缺陷: Ajax的核心...

  • 复习jQuery - ajax

    jQuery ajax - ajax() 方法 $.ajax({ url:'oo.php', ...

  • jQuery中Ajax请求的使用和四个步骤示例

    ajax() 方法用于执行 AJAX(异步 HTTP)请求,所有的 jQuery AJAX 方法都使用 ajax(...

  • ajax

    1、什么是ajax? 2、ajax的原理 3、ajax的核心对象 4、ajax的优点: ajax的缺点: 被jqu...

  • ajax

    Ajax 1 - 请求纯文本 Ajax 2 - 请求JSON数据 Ajax 3 - 请求Github接口 Ajax...

网友评论

      本文标题:AJAX

      本文链接:https://www.haomeiwen.com/subject/rkijhxtx.html