JSP的原生Ajax与解析Json

JSP的原生Ajax与解析JsonJSP的原生Ajax与解析Json

大家好,又见面了,我是你们的朋友全栈君。

JS原生Ajax

Ajax=异步Javascript+XML;
ajax是一种数据请求的方式,不需要刷新整个页面。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
ajax的核心技术当然是XMLHttpRequest对象;
ajax请求过程:创建XMLHttpRequest对象、连接服务器、发送请求、接受相响应数据。

<script type="text/javascript"> //调用ajax函数 ajax({ 
     url:'./TestXHR.aspx', type:'POST', dataType:'json', data:{ 
    name:"马各马它",age:18}, success:function(response,xml){ 
     //请求成功后执行的代码 }, error:function(status){ 
     //失败后执行的代码 } }); //创建ajax函数 function ajax(options){ 
     options=options||{ 
    }; optoins.type=(options.type||'GET').toUpperCase(); options.dataType=options.dataType||'json'; params=formatParams(options.data); //创建-第一步 var xhr; //非IE6 if(window.XMLHttpRequest){ 
     xhr=new XMLHttpRequest(); }else{ 
     //ie6及其以下版本浏览器 xhr=ActiveXObject('Microsoft.XMLHTTP'); } //接收-第三步 xhr.onreadystatechange=function(){ 
     if(xhr.readyState==4){ 
     var status=xhr.status; if(status>=200&&status<300){ 
     options.success&&options.success(xhr.responseText,xhr.responseXML); }else{ 
     options.error&&options.error(status); } } } //连接和发送-第二步 if(options.type=='GET'){ 
     xhr.open('GET',options.url+'?'+params,true); xhr.send(null); }else if(options.type=='POST'){ 
     xhr.open('POST',options.url,true); //设置表单提交时的内容类型 xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); xhr.send(params); } } //格式化参数 function formatParams(data){ 
     var arr=[]; for(var name in data){ 
     arr.push(encodeURIComponent(name)+'='+encodeURIComponent(data[name])); } arr.push(('v='Math.random()).replace('.','')); return arr.join('&'); } </script>

  • 创建
    兼容各个版本的浏览器。
  • 连接和发送
  1. open(method,url,async):规定请求类型(POST或GET)、请求地址url、异步(true)同步(false).大多都是异步;
    通过 AJAX,JavaScript 无需等待服务器的响应,而是: 在等待服务器响应时执行其他脚本,
    当响应就绪后对响应进行处理.
  2. GET请求方式是通过URL参数将数据提交到服务器的,POST则是通过将数据作为send的参数提交到服务器;
  3. POST请求中,在发送数据之前,要设置表单提交的内容类型;
  4. 提交到服务器的参数必须经过encodeURIComponent()方法进行编码,实际上在参数列表“key=value”的形式中,key和value都需要进行编码,因为胡包含特殊字符。每次请求的时候都会在参数列表中拼入一个“v=xx”的随机字符串,这样是为了拒绝缓存,每次都直接请求到服务器上。
    encodeURI():用于整个URI的编码,不会对本身属于URI的特殊字符串进行编码,如 : / ? # 其对应的解码函数decodeURI();
    encodeURIComponent():用于对URI中的某一部分进行编码,会对它发现的任何非标准字符进行编码;其他对应的解码函数decodeURIComponent();
  5. setRequestHeader(header,value):向请求添加请求头。header:规定头的名称,value:规定头的值。
  • 接收
  1. 接收到响应后,响应的数据会自动填充XHR对象,相关属性如下
    responseText:获得字符串形式的响应数据;
    responseXML:获得XML形式的响应数据;
    status:响应的HTTP状态码;
    statusText:HTTP状态的说明;
  2. XHR对象的readyState属性表示请求/响应过程的当前活动阶段,这个属性的值如下
    0-未初始化,尚未调用open()方法;
    1-启动,调用了open()方法,未调用send()方法; 服务器连接已建立;
    2-发送,已经调用了send()方法,未接收到响应; 请求已接收;
    3-接收,已经接收到部分响应数据; 请求处理中;
    4-完成,已经接收到全部响应数据; 请求已完成;
    只要 readyState 的值变化,就会调用 readystatechange 事件,(其实为了逻辑上通顺,可以把readystatechange放到send之后,因为send时请求服务器,会进行网络通信,需要时间,在send之后指定readystatechange事件处理程序也是可以的,我一般都是这样用,但为了规范和跨浏览器兼容性,还是在open之前进行指定吧)。
  3. 在readystatechange事件中,先判断响应是否接收完成,然后判断服务器是否成功处理请求,xhr.status 是状态码,状态码以2开头的都是成功,304表示从缓存中获取,上面的代码在每次请求的时候都加入了随机数,所以不会从缓存中取值,故该状态不需判断。
  4. ajax请求是不能跨域的!

JSONP

JSONP(JSON with Padding) 是一种跨域请求方式。主要原理是利用了script 标签可以跨域请求的特点,由其 src 属性发送请求到服务器,服务器返回 js 代码,网页端接受响应,然后就直接执行了,这和通过 script 标签引用外部文件的原理是一样的。
JSONP由两部分组成:回调函数和数据,回调函数一般是由网页端控制,作为参数发往服务器端,服务器端把要返回的数据拼成字符串作为函数的参数传入。
比如网页端创建一个 script 标签,并给其 src 赋值为 http://www.example.com/json/?callback=process, 此时网页端就发起一个请求。服务端将要返回的数据拼好最为函数的参数传入,服务端返回的数据格式类似”process({‘name’:’example’})”,网页端接收到了响应值,因为请求者是 script,所以相当于直接调用 process 方法,并且传入了一个参数。
单看响应返回的数据,JSONP 比 ajax 方式就多了一个回调函数。

function jsonp(options) {
        options = options || {};
        if (!options.url || !options.callback) {
            throw new Error("参数不合法");
        }
        //创建 script 标签并加入到页面中
        var callbackName = ('jsonp_' + Math.random()).replace(".", "");
        var oHead = document.getElementsByTagName('head')[0];
        options.data[options.callback] = callbackName;
        var params = formatParams(options.data);
        var oS = document.createElement('script');
        oHead.appendChild(oS);
        //创建jsonp回调函数
        window[callbackName] = function (json) {
            oHead.removeChild(oS);
            clearTimeout(oS.timer);
            window[callbackName] = null;
            options.success && options.success(json);
        };
        //发送请求
        oS.src = options.url + '?' + params;
        //超时处理
        if (options.time) {
            oS.timer = setTimeout(function () {
                window[callbackName] = null;
                oHead.removeChild(oS);
                options.fail && options.fail({ message: "超时" });
            }, time);
        }
    };
    //格式化参数
    function formatParams(data) {
        var arr = [];
        for (var name in data) {
            arr.push(encodeURIComponent(name) + '=' + encodeURIComponent(data[i]));
        }
        return arr.join('&');
    }

1、因为 script 标签的 src 属性只在第一次设置的时候起作用,导致 script 标签没法重用,所以每次完成操作之后要移除;
2、JSONP这种请求方式中,参数依旧需要编码;
3、如果不设置超时,就无法得知此次请求是成功还是失败;

JSON 字符串转换为 JavaScript 对象并取值

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body>
<h2>为 JSON 字符串创建对象</h2>
<p id="demo"></p>
<script> var text = '{ "sites" : [' + '{ "name":"Runoob" , "url":"www.runoob.com" },' + '{ "name":"Google" , "url":"www.google.com" },' + '{ "name":"Taobao" , "url":"www.taobao.com" } ]}'; obj = JSON.parse(text); document.getElementById("demo").innerHTML = obj.sites[1].name + " " + obj.sites[1].url; </script>
</body>
</html>
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106667.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月22日 下午3:20
下一篇 2022年4月22日 下午3:20


相关推荐

  • poi技术实现Excel导入_java json库

    poi技术实现Excel导入_java json库J2EE下Excel转JSON题外话:苦逼毕业狗,在北京做Android还没毕业就10K,回到长沙后连个面试机会都没有。毕业狗总是被瞧不起没有工作经验,好歹我在北京干了大半年呢。一是Android开发太饱和了,门槛低,谁学谁会,二是Android原生开发不行了,在Hybrid混合式和FaceBook主推的ReactNative新开发模式下,越来越多新型创业公司钟情于后两种开发模式。所以我果断抛弃An

    2022年5月3日
    88
  • table文字水平垂直居中

    table文字水平垂直居中lt table gt nbsp nbsp lt tr gt nbsp nbsp nbsp nbsp lt tdstyle text align center vertical align middle gt nbsp nbsp nbsp nbsp nbsp nbsp 文字内容 nbsp nbsp nbsp nbsp nbsp nbsp text align center 设置水平居中 nbsp nbsp nbsp nbsp nbsp nbsp vertical align middle 设置垂直居中 nbsp nbsp nbsp nbsp

    2025年12月14日
    6
  • java各种集合类区别

    java各种集合类区别最近面试经常遇到java集合类的问题,上网搜了一下,做个笔记百度的图集合类型主要有3种:set(集)、list(列表)和map(映射)。集合接口分为:Collection和Map,list、set实现了Collection接口List总结:可以重复,通过索引取出加入数据,顺序与插入顺序一致,可以含有null元素ArrayList:底层数据结构使数组结构array,…

    2022年6月9日
    29
  • 【GCC编译】GCC 使用中常用的参数及命令

    【GCC编译】GCC 使用中常用的参数及命令转载 gcc 使用中常用的参数及命令 本文转载自 http www cnblogs com yaozhongxiao archive 2012 03 16 2400473 html 如需转载 请注明原始出处 谢谢

    2026年3月19日
    1
  • DeepSeek 文案违禁词审查【指令+教程】.docx

    DeepSeek 文案违禁词审查【指令+教程】.docx

    2026年3月16日
    3
  • QT之计算器核心解析算法(十)

    QT之计算器核心解析算法(十)

    2022年3月13日
    40

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号