AJAX

作者: 南山码农 | 来源:发表于2017-08-08 12:39 被阅读0次

题目1: ajax 是什么?有什么作用?

Ajax是Asynchronous JavaScript and XML的缩写,这一技术能够向服务器请求额外的数据而无需卸载整个页面,会带来良好的用户体验。

AJAX 在浏览器与 Web 服务器之间使用异步数据传输(HTTP 请求)从服务器获取数据

这里的异步是指脱离当前浏览器页面的请求、加载等单独执行,这意味着可以在不重新加载整个网页的情况下,通过JavaScript发送请求、接受服务器传来的数据,然后操作DOM将新数据对网页的某部分进行更新,使用Ajax最直观的感受是向服务器获取新数据不需要刷新页面等待了

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

前后端开发联调中需要注意的是数据的传输,即需要事先协议好前端传入后台的请求,后端穿回前端的数据,浏览器发出请求即服务器发回数据,这是前后端沟通的渠道。
因此,在后端接口完成前,我们可以使用node.js中server-mock在本地模拟后端,虚拟出后端传回来的数据,前端对数据进行运行处理,以检测前端网页的功能。

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

防止重复点击有两种思路:
1.在服务器数据到来之前,忽略用户的重复点击;
2.服务器对用户的重复请求进行判断,如果请求相同,则只返回一组数据。
这两种思路分别是对应前端和后端。
思路1就是在前端对用户的操作进行判断,类似于之前的密码验证,能有效阻止90%的不当操作,更为有效的提高服务器速率。
前端对重复点击进行判断,只需要给发送的请求添加一个状态锁的属性,在服务器数据到来之前,状态锁为false,来之后为true,然后在浏览器发送请求前对状态锁进行判断。

 <script>
      var btn = document.querySelector('.layout > a')
      var ct = document.querySelector('#show')
      var isLoading = false;//状态锁设置初始状态

  function getrRndomint(min,max){
    return Math.floor(Math.random()*(max-min+1)+min)
  }

  btn.addEventListener('click',function(e){
    e.preventDefault();

    var xhr = new XMLHttpRequest()

    if (isLoading) {
      return ;
    };//对状态进行判断,阻止重复点击
    xhr.onreadystatechange = function(){
     if(xhr.readyState === 4 && (xhr.status === 200 || xhr.status === 304)){
      var data = JSON.parse(xhr.responseText)
      ct.innerHTML= '';
      for (var i = 0; i< data.length; i++) {
        var image = document.createElement('img')
        image.src = data[i]
        ct.appendChild(image)
      }
      console.log(data)
     }
     isLoading = false;//收到后台数据,状态锁为false
   }

  xhr.open('get', '/picture?number=' + (getrRndomint(3,6)), true)
  xhr.send()
  isLoading = true;// 发送请求后未收到后台数据,状态锁为true
  })
</script>

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

切换图片(图片资源来自后台)

相关文章

  • 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/zonzlxtx.html