AJAX JSON

1、AJAX

  [1] AJAX简介

        > 全称: Asynchronous JavaScript And XML
        > 异步的JavaScript和XML
        > AJAX就是通过JavaScript向服务器发送请求,并接收响应,然后我们在通过DOM来修改页面。
        > XML指的是服务器响应的数据的格式。
        > 目前AJAX已经很少使用XML作为响应的格式。因为XML的解析性能及传输性能较差。

  [2] 同步和异步

        >  同步:
            当我们通过浏览器向服务器发送一个请求时,浏览器会刷新整个页面。
        > 异步:
            当我们向服务器发送请求时,不是刷新整个网页,而是只刷新网页的一部分。

  [3] XMLHttpRequest对象

        > 我们AJAX的所有操作都是围绕着XMLHttpRequest对象进行。
        > 在XMLHttpRequest对象中封装发送给服务器请求报文,同时在服务器发回响应时,响应信息也会在对象中封装。
        > 如何获取XMLHttpRequest对象
            - var xhr = new XMLHttpRequest();

  [4] 使用步骤

        1.创建XMLHttpRequest对象
            大部分比较新的浏览器都支持的方式(IE7以上)
                var xhr = new XMLHttpRequest();
            IE6以下的
                var xhr = new ActiveXObject("Msxml2.XMLHTTP");
            IE5.5以下的
                var xhr = new ActiveXObject("Microsoft.XMLHTTP");
                
            通用的获取XMLHttpRequest对象的方法:
            
         

            //写一个获取XHR的方法function getXMLHttpRequest(){try{//大部分浏览器都支持的方式return new XMLHttpRequest();}catch(e){try{//IE6以下浏览器支持的方式return new ActiveXObject("Msxml2.XMLHTTP");}catch(e){try{//IE5以下的浏览器return new ActiveXObject("Microsoft.XMLHTTP");}catch(e){alert("你是火星来的吧!你的浏览器不支持AJAX!");}}}}

        
        2.设置请求信息(请求地址,请求方式,请求参数)
            xhr.open(请求方式,请求地址);
            在发送post请求时,还需要设置一个请求头,如下:
                xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
        
        3.发送请求
            xhr.send(请求体);
            get请求没有请求体,所以send中可以传null或什么都不传。
            post请求需要通过send来设置请求参数。
            
        
        4.接收响应信息
           

             //xhr绑定一个onreadystatechange响应函数,这个函数会在readyState属性发生改变时调用xhr.onreadystatechange = function(){//判断当前readyState是否为4 , 且响应状态码为200if(xhr.readyState==4 && xhr.status==200){//读取响应信息,做相关操作。//如果信息为纯文本xhr.responseText//如果信息为XMLxhr.responseXML}};

            readyState属性存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。
                0: 请求未初始化
                1: 服务器连接已建立
                2: 请求已接收
                3: 请求处理中
                4: 请求已完成,且响应已就绪
           status--------- 200: "OK"
                                404: 未找到页面       

    [5] 响应数据的格式

        - 响应一个XML
        - 当我们想通过servlet给ajax返回一个比较大量的信息,返回一个对象。
        - 返回 User :username:sunwukong  age:18 gender:男
            username:sunwukgon,age:18,gender:男
        - 我们可以通过一个XML格式来返回一个大量的信息
            <user>
                <name></name>
                <age></age>
                <gender></gender>
            </user>
            
        - 响应一个JSON对象
       
        


2、JSON

    [1] JSON简介

        > JSON全称 JavaScript Object Notation
        > 类似于JS中对象的创建的方法
        > JSON和XML一样,都是一种表示数据的格式
        > 但是JSON比XML的存储和解析性能要高的多,JSON要比XML高个30%左右。
            <user>
                <name>sunwukong</name>
                <age>18</age>
                <gender>男</gender>
            </user>
            
            {"name":"孙悟空","age":8,"gender":男}        

    [2] JSON的格式


        > JSON字符串不方便阅读,但是传输性能好
        > XML方便阅读,但是传输性能差
        > JSON的格式和JS对象类型,但是要求属性名必须使用双引号。
        > JSON对象中实际就是一组一组的键值对的结构,
            键和值使用“:”连接,多个键值对之间使用“,”分开,注意如果是最后一组键值对,则千万不要在加“,”
        > {
            "属性名1":属性值1,
            "属性名2":属性值2,
            "属性名3":属性值3,
            "属性名4":属性值4
          }
        
        > JSON运行属性值的类型:
            1.字符串
            2.数字
            3.布尔
            4.对象{}
            5.数组[]
            6.null
            
        > 数组:
            [属性1,属性2,属性3,属性4]
    

 [3] JS中使用JSON    


        对象 --> JSON字符串
            JSON.stringify(对象)
        JSON --> 对象
            JSON.parse(JSON字符串)
            
    ===============================================================================
            /*
            区分js对象和json对象
             js对象的属性名不需要使用双引号引起来
             json对象的属性名必须使用双引号引起来
            
            //区分json对象和字符串
            json对象对象外边使用单引号('')括起来就是字符串对象
            
            json对象和字符串对象之间的转换
                字符串--->json对象[JSON.parse(str)]
                json对象-->字符串[JSON.stringify(obj)]
        */

    ===============================================================================
    


    [4] Java中使用JSON


        > 目前Java中用的比较多的JSON解析工具:
            json-lib -->  使用麻烦,解析性能最差
            Jackson --> 使用较麻烦,解析性能最好
            Gson --> 使用简单,解析性能中能
                - Gson是谷歌出的一款JSON解析工具,使用简单,且性能较好。
    
        Java对象 --> JSON字符串
        
        JSON --> Java对象


3、通过jQuery实现AJAX

    > 使用get和getJSON都会有缓存问题,并且使用get方法不能传送较多的数据。
    > post方法不会有缓存的问题,所以我们开发时使用post方法较多。

    [1] post()方法    

        $.post(url, [data], [callback], [type])
        参数:
            url:发送AJAX的请求地址,字符串。
            data:发送给服务器的请求参数,JSON格式。
            callback:当前需要获取服务器发送的响应时,我们可以通过该回调函数。
                jQuery会将响应信息以回调函数的参数的形式返回
            type:响应信息的类型,字符串。一般两个常用值text、json    

    [2] get()方法

        - get方法和post方法使用方式基本一致。    

    [3] getJSON()方法

            getJSON(url, [data], [callback])
            getJSON方法和get方法类似,只不过该方法默认的响应类型为JSON,不需要再手动指定。
            
           


更多专业前端知识,请上 【猿2048】www.mk2048.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/361094.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在WildFly 8.2中修补焊接3 – Java EE 8的第一个实验RI

Java EE 8一直在发展&#xff0c;并且已经提出了几个新的组件JSR。 JSR 365将定义CDI 2.0的规范。 红帽公司已经开始研究Weld 3的实现原型&#xff0c;并且Alpha3最近发布了 。 Red Hat的Java EE 8兼容应用服务器将是WildFly&#xff0c;将在其中实现所有不同的技术。 同时&am…

mat-form-field must contain a MatFormFieldControl错误的解决方法

下面的代码竟然出错了&#xff1a; <mat-form-field><input matInput placeholder"输入名称"></mat-form-field> 错误提示的莫名其妙&#xff0c;其实只要导入以下模块就可了&#xff1a; imports: [MatFormFieldModule,MatInputModule,] 更多专业…

lua# lua5.1.4 源码文件作用一览

写了个脚本列出lua源码C文件头部的注释&#xff0c;作为我有一搭没一搭以Lua为对象学习编译原理的开端。 lua5.1.4全部的源码有35个C文件&#xff0c;17216行代码。每个文件基本的功能如下 ./output_lua_sources_comments.sh ~/resources/sources/lua/src …

带有Hibernate OGM的NoSQL –第一部分:持久化您的第一个实体

Hibernate OGM的第一个最终版本已经发布 &#xff0c;团队从发布狂潮中恢复了一些。 因此&#xff0c;他们考虑建立一系列教程式博客&#xff0c;使您有机会轻松地从Hibernate OGM重新开始。 感谢Gunnar Morling&#xff08; gunnarmorling &#xff09;创建了本教程。 介绍 不…

为自己写程序之JavsScript代码段测试器

JavaScript的测试&#xff0c;通常是在Firefox的firebug插件中测试的。不过有时只是测试几行代码都要写一个html&#xff0c;再打开浏览器测试运行结果&#xff0c;感觉并不是很方便。 今天花了点时间做了一个简易的JS片段测试器。其实这主要是看了IronJs开源项目以后&#xff…

sizeof和strlen的区别(其中涉及NUL的讲解)

本文是自己结合平时所学的知识&#xff0c;对sizeof和strlen的区别进行了总结&#xff0c;如有不对的地方还请批评指证&#xff0c;共同进步&#xff01;&#xff01;&#xff01; 一、从C语言的定义上来讲 1、sizeof是关键字&#xff0c;而strlen是包含在string.h头文件中的一…

我的Wiki:使用JConsole对WildFly(或JBoss AS7)进行远程JMX访问

与以前的版本相比&#xff0c;JBoss AS7的目标之一是使其在默认情况下更加安全。 受此目标直接影响的领域之一是&#xff0c;您不再期望服务器在端口上公开某些服务&#xff0c;而无需任何身份验证/授权就可以访问它。 请记住&#xff0c;在以前的JBoss AS版本中&#xff0c;只…

js判断对象类型

1.typeof typeof只能判断区分基本类型&#xff0c;number、string、boolean、undefined和object,function&#xff1b; typeof 0; //number; typeof true; //boolean; typeof undefined; //undefined; typeof "hello world" //string; typeof function(){}; …

我喜欢的类型

http://v.qq.com/cover/h/hfd581s2y9unvy8.html?vidp0011ocge8q 转载于:https://www.cnblogs.com/sliz/archive/2012/12/09/2809742.html

使用WildFly和Java EE 7映像与Docker提供者一起流浪

什么是无业游民&#xff1f; Vagrant是创建虚拟开发环境的简化且可移植的方式。 它可与多种虚拟化软件一起使用&#xff0c;例如VirtualBox&#xff0c;VMWare&#xff0c;AWS等。 它还可以与多种配置软件一起使用&#xff0c;例如Ansible&#xff0c;Chef&#xff0c;Puppet或…

Apache Nutch 1.6 发布

Apache Nutch 1.6 发布&#xff0c;该版本修复了超过 20 个 bug&#xff0c;新功能包括&#xff1a;新的 HostNormalizer&#xff0c;可通过 MIME-type 和 Indexer API 的功能增强来动态设置 fetchInterval &#xff0c;更新 Tika 到 1.2 版本&#xff0c;更新 Autimaton 到 1.…

EE Servlet 3:如何在Web应用程序中设置后端服务

在Web应用程序中&#xff0c;提供用户界面&#xff08;UI&#xff09;通常只是工作的一半。 许多应用程序都有后端服务支持的要求。 后端服务的一些示例是调度程序进程&#xff08;批处理&#xff09;&#xff0c;侦听队列并在消息进入时作出响应&#xff0c;或者是简单的事情&…

es6解构赋值

解构赋值语法是一个 Javascript 表达式,这使得可以将值从数组或属性从对象提取到不同的变量中。 数组解构赋值&#xff1a; {let a,b,rest;[a,b][1,2];console.log(a,b); //1 2 } {let a,b,rest;[a,b,...rest][1,2,3,4,5]; console.log(a,b,rest); //1 2 [ 3, 4, 5 ]…

Jquery插件之ajaxForm

如今ajax满天飞&#xff0c;作为重点的form自然也受到照顾。 其实&#xff0c;我们在平常使用Jquery异步提交表单&#xff0c;一般是在submit()中&#xff0c;使用$.ajax进行。比如&#xff1a; $(function(){$(#myForm).submit(function(){$.ajax({url:"/WebTest/test/te…

休眠锁定模式–乐观锁定模式如何工作

显式乐观锁定 在上一篇文章中 &#xff0c;我介绍了Java持久性锁定的基本概念。 隐式锁定机制可防止丢失更新 &#xff0c;它适用于我们可以主动修改的实体。 虽然隐式乐观锁定是一种广泛使用的技术&#xff0c;但是很少有人了解显式乐观锁定模式的内部工作原理。 当锁定的实…

CSS中可继承的属性

不可继承的属性太多了不要背&#xff0c;记住可以继承的属性有哪些就行了。可以继承的属性很少&#xff0c;只有颜色&#xff0c;文字&#xff0c;字体间距行高对齐方式&#xff0c;和列表的样式可以继承。这么来记很轻松的呀&#xff01;不要被下边的吓到了哦~所有元素可继承&…

如何在JMeter中执行客户端Web性能测试?

在本文中&#xff0c;我们将看到如何使用Jmeter插件进行客户端性能测试。 我将使用jmeter webdriver插件。 在开始本主题之前&#xff0c;请从我以前的文章中获得有关客户端性能测试的一些基本信息。 因此&#xff0c;让我们开始吧&#xff1a; 安装 通过这篇文章之后的链接&…

inline-block的兼容性问题

我们都知道在IE6 7 中用*display&#xff1a;block&#xff1b;*zoom&#xff1a;1&#xff1b;可以解决 inline-block 的兼容问题 很多人认为IE6 7 是不支持inline-block的&#xff0c;严格来说应该是&#xff1a;IE6 7 对 inline-block 支持的不够完全 这个要分两种情况来说&…

用Java读取/写入压缩和非压缩文件

这篇文章的主要原因是尝试不重复自己&#xff08; DRY &#xff09;&#xff0c;因为通常&#xff0c;我会遇到读写压缩和非压缩文件&#xff08;主要是JSON和CSV&#xff09;的递归需求。 首先让我们看看如何读取文本文件。 注意我正在使用&#xff08;相对较小的&#xff09…

Gradle入门:创建多项目构建

尽管我们只能使用一个模块来创建一个工作的应用程序&#xff0c;但是有时将我们的应用程序划分为多个较小的模块是比较明智​​的。 因为这是一个相当普遍的用例&#xff0c;所以每个自重的构建工具都必须支持它&#xff0c;Gradle也不例外。 如果Gradle项目具有多个模块&…