ajax和json

ajax介绍

问题:用户注册的时候,没有,用户名是否可用提示,导致用户需要反复的提交表单,用户体验不好。

优化:用户在书写完用户名,就有一个提示,告诉当前书写的用户名是否可用

Ajax 特点:

ajax 执行,不需要用户控制,自动发送请求和接收响应

ajax 发送请求的时候,依然按照 http 协议

ajax 请求和响应,数据量小

总结什么是 ajax:自动发送请求,接受响应,数据量非常小,依然按照 http 协议做网络的

传输,这个就是 ajax 技术。

获取 XMLHttpRequest 对象(ajax 核心对象,ajax 引擎)

<script type="text/javascript">

//获取 ajax 核心对象的方法

function getXHR() {

var xmlhttp;

if (window.XMLHttpRequest) {

// code for IE7+, Firefox, Chrome, Opera, Safari

xmlhttp = new XMLHttpRequest();

} else {

// IE6, IE5与其他浏览器不同

xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

}

return xmlhttp;

}

alert(getXHR());

</script>

向服务器发送请求——使用 open 方法和 send 方法

//测试使用 ajax 核心对象,发送请求

function test1(){

var xhr = getXHR();

xhr.open("get","/day18/ajax?username=张三",true);

//是什么:规定请求的类型、 URL 以及是否异步处理请求。

//当是post提交时请求参数放在send()中

xhr.send();

}

test1();

接收服务器响应

//测试 ajax 获取响应

function test2(){

var xhr = getXHR();

xhr.open("get","/day18/ajax?username=张三",true);

xhr.send();

/**

有一个妹子,半夜十二点,搜索一些东西

妹子(上海),百度的服务器(北京)(网络延迟)

服务器发送响应到浏览器(网络延迟)

为什么获取响应数据没有效果?

就是没有考虑网络延迟的问题

*/

//浏览器端准备接受响应

var data = xhr.responseText;

alert(data);

}

设置 onreadystatechange 事件执行函数(等待服务器响应)

//测试设置 ajax 等待服务器响应

function test3(){

//获取核心对象

var xhr = getXHR();

//设置等待服务器响应

xhr.onreadystatechange=function(){

//4: 请求已完成,且响应已就绪,200: "OK"

if (xhr.readyState==4 && xhr.status==200){

var data=xhr.responseText;

alert(data);

}

}

//发送请求

xhr.open("get","/day18/ajax?username=张三",true);

xhr.send();

}

test3()

ajax 小结(ajax 代码怎么写)

获取核心对象

设置等待服务器响应

发送请求

onreadystatechange 属性

是什么:

存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。

第三个参数 async: True(异步) 或 False(同步)?

async false 所有的请求和响应,需要排队执行(同步)

async true 所有的请求和响应,不需要排队执行(插队执行)(异步)

readyState 属性

存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。

status 属性

是什么:存储响应状态码

jQuery Ajax 支持的 API

jQuery 对 Ajax 的使用提供了非常好的封装,简单的很!

load(url, [data], [callback]) 载入 HTML 代码并插入至 DOM中,例如: $(“#mydiv”).load(“a.html”);

$.get(url, [data], [callback], [type]) Ajax 的 get 方式请求,一般用于获取数据

$.post(url, [data], [callback], [type]) Ajax 的 post 方式请求,一般用于发送表单数据

$.getJSON(url, [data], [fn]) Ajax 跨域获取服务器数据 例子: www.taobao.com 支付 www.alipay.com

$.getScript(url, [callback]) 载入并执行一个跨域的 js 文件

url:待载入页面的URL地址

data:待发送Key/value参数。

callback:载入成功时回调函数。

type:返回内容格,xml,html,script,json,text,_default.

$.ajax(url, [settings])

$.ajax({

//请求方式 type: "POST",

//请求路径 url: "${root}/ajax",

//发送参数  data: "name=John&location=Boston",

//返回的数据类型:

/**

"xml": 返回 XML 文档,可用 jQuery 处理。

"html": 返回纯文本 HTML 信息;包含的script标签会

在插入dom时执行。

"script": 返回纯文本 JavaScript 代码。

"json": 返回 JSON 数据 。

"jsonp": JSONP 格式。

"text": 返回纯文本字符串

*/

dataType: "text",

//回调函数

//请求成功的回调函数

success: function(msg){

alert( "Data Saved: " + msg );

},

//请求失败的回调函数

error:function(msg){

alert( "Error");

}

});

</script>

get

/*

url:待载入页面的URL地址

data:待发送 Key/value 参数。

callback:载入成功时回调函数。

type:返回内容格式, xml, html, script, json, text, _default。

*/

$.get("ajax", { name: "John", time: "2pm" },

function(data){

alert("Data Loaded1: " + data);

});

post

/*

url:待载入页面的URL地址

data:待发送 Key/value 参数。

callback:载入成功时回调函数。

type:返回内容格式, xml, html, script, json, text, _default。

*/

$.post("ajax", { name: "John", time: "2pm" },

function(data){

alert("Data Loaded2: " + data);

});

});

JSON 技术

Json 介绍

Xml 问题:导致传输的数据量变大,解析和创建的操作复杂

JSON 字符串转换为 JavaScript 对象:  eval() 或 JSON.parse() 方法

JavaScript对象转换为 JSON 对象:  JSON.stringify()

java对象转成JSON

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容