zoukankan      html  css  js  c++  java
  • Ajax

    AJAX的概述

    什么是AJAX
        AJAX:异步的 JavaScript And XML.
        用的是老的技术,用的是新的思想.
    AJAX的功能:完成页面的局部刷新,不中断用户的体验.
        早期的时候JS技术根本不受重视.后台开发人员经常将JS当成一种玩具式语言.JS中有一个对象XMLHttpRequest对象可以向服务器异步发送请求.传统的B/S结构的软件,所有实现功能都需要在服务器端编写代码(胖服务器).现在有了AJAX以后,可以将部分代码写到客户端浏览器(RIA:Rich Internet Application).FLEX:AS脚本编程.
        XML:使用XML做为数据传递的格式;JSON,也是一种传输格式。

    XMLHttpRequest

    属性:
    * readyState            :XMLHttpRequest的状态
      状态         名称     描述
      0     Uninitialized     初始化状态。XMLHttpRequest 对象已创建或已被 abort() 方法重置。
      1     Open             open() 方法已调用,但是 send() 方法未调用。请求还没有被发送。
      2     Sent             Send() 方法已调用,HTTP 请求已发送到 Web 服务器。未接收到响应。
      3     Receiving         所有响应头部都已经接收到。响应体开始接收但未完成。
      4     Loaded     HTTP     响应已经完全接收。
    * onreadystatechange    :当XMLHttpRequest状态改变的时候触发一个函数.
    * status                :获得响应的状态码. 200 , 404 ...
    * responseText            :获得响应的文本数据.
    * responseXML            :获得响应的XML的数据.

    方法:
    * open(请求方式,请求路径,是否异步)        :异步去向服务器发送请求.
    * send(请求参数)                        :发送请求.
    * setRequestHeader(头信息,头的值)        :处理POST请求方式的中文问题.

    创建XMLHttpRequest对象

    IE:将XMLHttpRequest对象封装在一个ActiveXObject组件。
    Firefox:直接就可以创建XMLHttpRequest对象。

    function createXmlHttp(){
       var xmlHttp;
       try{ // Firefox, Opera 8.0+, Safari
            xmlHttp=new XMLHttpRequest();
        }
        catch (e){
           try{// Internet Explorer
                 xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
              }
            catch (e){
              try{
                 xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
              }
              catch (e){}
              }
        }
        return xmlHttp;
     }

    AJAX的入门

    AJAX的编写的步骤
    * 第一步:创建一个异步对象.
    * 第二步:设置对象状态改变触发一个函数.
    * 第三步:设置向后台提交的路径
    * 第四步:发送请求.
    GET方式提交请求

    function ajax_get() {
        // 1.创建异步对象
        var xhr = createXMLHttp();
        // 2.设置状态改变的监听 回调函数.        //3和4这两步放在2之前更好理解
        xhr.onreadystatechange = function(){
            if(xhr.readyState == 4){ // 请求发送成功
                if(xhr.status == 200){ // 响应也成功
                    // 获得响应的数据:
                    var data = xhr.responseText;
                    // 将数据写入到DIV中:
                    document.getElementById("d1").innerHTML = data;
                }
            }
        }
        // 3.设置请求路径
        xhr.open("GET","/day15/ServletDemo1?name=aaa&pass=123",true);
        // 4.发送请求
        xhr.send(null);
    }

    POST方式提交请求

    function ajax_post(){
        // 创建异步对象:
        var xhr = createXMLHttp();
        // 设置监听:
        xhr.onreadystatechange = function(){
            if(xhr.readyState == 4){
                if(xhr.status == 200){
                    document.getElementById("d1").innerHTML = xhr.responseText;
                }
            }
        }
        // 打开路径:
        xhr.open("POST","/day15/ServletDemo1",true);
        xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");//必须在xhr.open()的后面
        // 发送请求:
        xhr.send("name=张三&pass=123");        //发送了中文参数,要在路径的对象中,进行转码request.setCharacterEncoding("UTF-8");
    }



    异步校验用户名
    【步骤一】:创建表和数据库:
    【步骤二】:设计一个注册页面
    【步骤三】:在用户名的文本框中使用onblur事件触发一个函数.
    【步骤四】:AJAX的异步操作,将文本框的值传入到Servlet中.
    【步骤五】:Servlet中根据传入的用户名去数据库进行查询.
    【步骤六】:查询到了说明用户名已经被占用,没有查询到说明用户名可以使用.

    创建数据库和表:
    create database web_15;
    use web_15;
    create table user(
        id int primary key auto_increment,
        username varchar(20),
        password varchar(20),
        nickname varchar(20),
        type varchar(20)
    );
    insert into user values (null,'aaa','111','小凤','user');
    insert into user values (null,'bbb','111','小森','user');
    
    代码实现:
    function checkUsername(){
        // 获得文本框的值:
        var username = document.getElementById("username").value;
        // 创建异步对象:
        var xhr = createXMLHttp();
        // 设置监听:
        xhr.onreadystatechange = function(){
            if(xhr.readyState == 4){
                if(xhr.status == 200){
                    var data = xhr.responseText;
                    if(data == 1){
                        document.getElementById("s1").innerHTML = "<font color='green'>用户名可以使用</font>";
                        document.getElementById("regBut").disabled = false;
                    }else if(data == 2){
                        document.getElementById("s1").innerHTML = "<font color='red'>用户名已经被占用</font>";
                        document.getElementById("regBut").disabled = true;
                    }
                }
            }
        }
        // 打开连接:
        xhr.open("GET","/day15/ServletDemo2?username="+username,true);
        // 发送请求:
        xhr.send(null);
    }
    异步校验用户名

    【JQuery的AJAX】
    JQuery的AJAX部分方法
      Jq的对象.load(路径,参数,回调函数);
      $.get(路径,参数,回调函数,数据类型);
      $.post(路径,参数,回调函数,数据类型);
      $.ajax();
      serialize(); -- JQ的AJAX传递参数的时候需要使用的方法.

    JQ异步校验用户名
    【步骤一】:创建表和数据库:
    【步骤二】:设计一个注册页面
    【步骤三】:在用户名的文本框中使用onblur事件触发一个函数.
    【步骤四】:使用JQ的AJAX完成异步操作,将文本框的值传入到Servlet中.
    【步骤五】:Servlet中根据传入的用户名去数据库进行查询.
    【步骤六】:查询到了说明用户名已经被占用,没有查询到说明用户名可以使用.

    $(function(){
        $("#username").blur(function(){
            // 获得文本框的值:
            var username = $(this).val();
            // 演示load方法:
            // $("#s1").load("/day15/ServletDemo3",{"username":username});
            // 演示get/post方法:
            $.get("/day15/ServletDemo3",{"username":username},function(data){
                if(data == 1){
                    $("#s1").html("<font color='green'>用户名可以使用</font>");
                    $("#regBut").attr("disabled",false);
                }else if(data == 2){
                    $("#s1").html("<font color='red'>用户名已经存在</font>");
                    $("#regBut").attr("disabled",true);
                }
            });
        });
    });
    JQ异步校验用户名

    JQ完成输入框提示
    【步骤一:】设计一个商品的搜索页面.
    【步骤二:】keyup事件触发一个函数.
    【步骤三:】获得文本框的值,提交到Servlet中
    【步骤四:】在Servlet中根据提交名称查询相应信息.(显示5个)

    create table words(
        id int primary key auto_increment,
        word varchar(20)
    );
    
    代码实现:
    $(function(){
        // 为文本框绑定事件:
        $("#word").keyup(function(){
            // 获得文本框的值:
            var word = $(this).val();
            // 异步发送请求:
            if(word != ""){
                $.post("/day15/ServletDemo4",{"word":word},function(data){
                    $("#d1").show().html(data);
                });
            }else{
                $("#d1").hide();
            }
        });
    });
    JQ完成输入框提示

    JQ完成省市联动
    【AJAX的响应的数据】
    文本,一段HTML的数据,XML,JSON
    【使用工具生成XML的文件】
    通常使用xStream工具. 将集合,数组,对象转成XML.

    【步骤一】:使用注册页面中省市的下拉列表.
    【步骤二】:当省份发生变化,触发一个事件.
    【步骤三】:将选择的省份的信息传入到Servlet中.
    【步骤四】:根据省份信息查询市的信息.
    【步骤五】:将查询到市的信息转成XML.
    【步骤六】:获得XML的指定信息,显示到第二个列表中.

    Jsp引入的js把选择的省份id传入,再把结果返回给js中function的data
    public class ServletDemo6 extends HttpServlet { 
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            try {
                //接收数据
                String pid = request.getParameter("pid");
                //调用业务层查询所有的市的信息
                ProvinceService provinceService = new ProvinceService();
                List<City> list = provinceService.findByid(pid);
                //将list生成XML
                XStream xStream = new XStream();
                //修改标签名
                xStream.alias("city", City.class);    //改变list中对象的生成的标签名
                //将类中属性作为标签的属性
                /*xStream.useAttributeFor(City.class, "cid");
                xStream.useAttributeFor(City.class,"cname");
                xStream.useAttributeFor(City.class,"pid");*/
                
                String xmlStr = xStream.toXML(list);
                //System.out.println(xmlStr);
                response.setContentType("text/xml;charset=UTF-8");
                response.getWriter().println(xmlStr);
            } catch (SQLException e) {
                e.printStackTrace();
                throw new RuntimeException();
            }
        }
    ...
    }
    
    $(function(){
        // 为省份下拉列表绑定事件:
        $("#province").change(function(){
            // 获得选中的省份的id:
            var pid = $(this).val();
            // alert(pid);
            $.post("/day15/ServletDemo6",{"pid":pid},function(data){
                // alert(data);
                var $city = $("#city");
                $city.html("<option>-请选择-</option>");
                $(data).find("city").each(function(){
                    var cid = $(this).children("cid").text();
                    var cname = $(this).children("cname").text();
                    
                    $city.append("<option value='"+cid+"'>"+cname+"</option>");
                });
            });
        });
    });
    JQ完成省市联动

    JQ完成省市联动——使用JSON作为响应数据
    JSONLIB 转换JSON数据
      JSONArray:将数组或List集合转成JSON。
      JSONObject:将对象或Map集合转成JSON。

    Jsp引入的js把选择的省份id传入,再把结果返回给js中function的data
    public class ServletDemo8 extends HttpServlet {
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            try {
                String pid = request.getParameter("pid");
                ProvinceService provinceService = new ProvinceService();
                List<City> list = provinceService.findByid(pid);
                
                //将list集合转成json
                JsonConfig config = new JsonConfig();
                config.setExcludes(new String[]{"pid"});
                JSONArray jsonArray = JSONArray.fromObject(list,config);    //生成的json对象不包含pid
                response.setContentType("text/html;charset=UTF-8");
                response.getWriter().println(jsonArray.toString());
            } catch (SQLException e) {
                e.printStackTrace();
                throw new RuntimeException();
            }
        }
    ...
    }
    
    $(function(){
        // 为省份下拉列表绑定事件:
        $("#province").change(function(){
            var pid = $(this).val();
            $.post("/day15/ServletDemo8",{"pid":pid},function(data){
                // alert(data);
                // JS识别JSON:
                // var json = eval(data);
                var $city = $("#city");
                $city.html("<option>-请选择-</option>");
                $(data).each(function(i,n){
                    // alert(n.cname);
                    $city.append("<option value='"+n.cid+"'>"+n.cname+"</option>");
                });
            },"json");
        });
    });
    JQ完成省市联动——使用JSON作为响应数据
  • 相关阅读:
    Halcon图像分割
    Halcon图像变量
    C# 线程同步
    C# 单例模式实现
    C# 限制窗体弹窗显示必须关闭后才能重新实例化窗体
    Java定时清理过期文件
    GrayLog + Logspout + Docker 实现分布式日志聚合
    基于Spring Security OAuth2搭建的Spring Cloud 认证中心
    快速搭建Docker Registry私有仓库
    让你的Spring Boot应用快速运行在Docker上面
  • 原文地址:https://www.cnblogs.com/boomoom/p/10462786.html
Copyright © 2011-2022 走看看