ajax

作者: ahong_吴 | 来源:发表于2016-11-26 19:22 被阅读28次

问答

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

  • AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。
  • 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
  • 所谓异步,就是向服务器发送请求的时候,我们不必等待结果,而是可以同时做其他的事情,等到有了结果我们可以再来处理这个事。

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

  • 联调
    约定好需要传输的数据和接口,包括请求的类型get/post,请求url,数据的格式等
  • mock数据
  • 安装nodejs,在系统终端中输入npm install -g server-mock安装mock
  • mock init 初始化数据,mock start开始;
  • 生成的三个文件中,index.html为静态页面,router.js为后端接口文件,user.ejs为静态页面分隔的模板文件。

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

  • 上锁:
var isDataArrive=true;  
xxx.addEventListener('click',function(){  
  if(!isDataArrive) return; 
  yyy.onreadystatechange=function(){
    if(){
      if(){}
      isDataArrive=true;                
    }  
    yyy.open();
    yyy.send();    
    isDataArrive=false;
  };  
}

代码

1.封装一个 ajax 函数,能通过如下方式调用

function ajax(opts){

        var xmlhttp = new XMLLHttpRequest();
        xmlhttp.onreadystatechange = function(){
          if(xmlhttp.readyState == 4 && xmlhttp.status == 200){
            var json = JSON.parse(xmlhttp.responseText);
            opts.success(json);
          }
          if(xmlhttp.status == 404){
            opts.error();
          }
        }
        var dataStr = '';
        for(var key in opts.data){
          dataStr += key + '=' + opts.data[key] + '&';
        }
        dataStr = dataStr.substr(0, dataStr.length-1);

        if(opts.type.toLowerCase() === 'post'){
          xmlhttp.open(opts.type, opts.url, true);
          xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
          xmlhttp.send(dataStr);
        }
        if(opts.type.toLowerCase() === 'get'){
          xmlhttp.open(opts.type, opts.url + '?' + dataStr, true);
          xmlhttp.send();
        }
      }


      document.getElementById('btn').addEventListener('click',function(){
        ajax({
          url:'use_ajax.php',
          type:'get',
          data:{
            username:document.getElementById('username').value
          },
          success:function(data){
            console.log(data);//dealWith(data);
          },
          error:function(){
            console.log("错误");//onError();
          }
        });
      });

2.实现如下加载更多的功能。

任务24-2 代码
新浪云预览

3.实现注册表单验证功能

任务24-3 代码
新浪云预览

相关文章

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