ajax课2JSON
1.ajax优点:
a.页面无刷新
b.用户体验度较好,不会打断用户操作
c.按需求获取数据,不需要返回一个完整的页面
d.是标准的技术,不需要安装任何的插件
应用场景:注册、表格数据的增删改
2.JSON(javascript object motation js对象声明)
是一种轻量级的数据交换标准,一般用于浏览器与服务器的数据交换
数据交换:
将数据转换成中间的,与平台无关的格式数据
轻量级:解析速度比xml快,相对于xml而言,编写方便别情解析速度较快
JSON语法:
{key:value,key:value...}
1)使用json表示单个js对象
{"name":"zs","age":10}
属性名需要加"",属性值如果是string类型需要加"",数值类型则不需要加""
js类型:string,number,boolean,object,null,undefind (只有string需要加"")
2)使用json表示js数组对象
[{key:value},{key:value},{key:value}...]
3.java对象转成json对象
a.单个对象
JSONObject.formObject(obj).toString();
b.多个对象(集合,数组)
JSONArray.fromObject(obj).toString();
注:如果是Map,建议调用JSONObject转换成数据格式
package test; import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import net.sf.json.JSONArray;
import net.sf.json.JSONObject; import org.junit.Test; import entity.User; public class UestJSON {
@Test
public void test1(){
User u=new User("账单",10);
String data= JSONObject.fromObject(u).toString();
System.out.println(data);
} @Test
public void test2(){
List<User> list=new ArrayList<User>();
User u1=new User("张龙",10);
User u2=new User("张虎",23);
list.add(u1);
list.add(u2);
String data=JSONArray.fromObject(list).toString();
System.out.println(data);
} @Test
public void test3(){
User u1=new User("张龙",10);
User u2=new User("张虎",23);
User[] us={u1,u2};
String data=JSONArray.fromObject(us).toString();
System.out.println(data);
} @Test
public void test4(){
Map<String,Object> map=new HashMap<String,Object>();
User u1=new User("张龙",10);
User u2=new User("张虎",23);
map.put("u1",u1);
map.put("u2",u2);
String data=JSONObject.fromObject(map).toString();
System.out.println(data);
}
}
4.json字符串转成js对象
evalJSON()-->proptotype.js
5.jQuery对ajax的支持
{key:value...}
$.ajax({options});
url:请求地址
type:请求方式get/post
data:参数{"value":"js"}或者"value=js",
dataType:服务器返回的数据类型 json,xml,js,html,text等等
success:成功的回调函数
function(data,txt){
//data:服务器返回的数据
//txt:状态描述信息
},
error:失败的回调函数
function(xhr,txt){
//xhr:ajax对象
//txt:状态描述信息
},
简写:$.get(url,[data],[callback],[type]);
$.post(url,[data],[callback],[type]);
url:请求地址
data:请求参数
callback:成功的回调函数
type:服务器返回的数据类型
6.热卖商品动态展示(每隔5秒钟,向后台发一次请求)
step1.设计表
create table sale(id int primary key auto_increment,name varchar(30),qty int);
insert into sale values(null,'小米盒子',80);
insert into sale values(null,'小米手机',90);
insert into sale values(null,'小米路由',70);
insert into sale values(null,'小米台灯',85);
insert into sale values(null,'小米音响',80);
step2.定义实体类Sale
step3.定义DAO接口
List<Sale> findTop() throws Exception;
step4.定义DAO实现类
select*from sale order by qty desc limit 3;
step5.定义ActionServlet
step6.定义sale.html 写脚本,ajax向后台发请求
function f1(){ 使用ajax向服务器发请求(sale.do)};
function f2(){ setInterval(f1,5000)};
<body onload="f2();" >
ajax课2JSON的更多相关文章
- ajax课1 源码
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...
- CSS之表单元素
表单就是收集用户信息的,就是让用户填写的.选择的. 1 <div> 2 <h3>欢迎注册本网站&l ...
- HTML标签----图文详解(二)
HTML标签超详细的图文演示再来一波~~~ 如果还没有看过昨天的福利的,那可要抓紧喽,传送门:HTML标签----图文详解 本文主要内容 列表标签 表格标签 框架标签及内嵌框架<iframe&g ...
- css--小白入门篇1
一.引入 css用来描述html,学习css前我们先来学习html的基础标签的用法,再进入css的学习. 本教程面向小白对象,不会讲细枝末节深入的东西. 二.列表 列表有3种 2.1 无序列表 无序列 ...
- 01_互联网基本原理和HTML入门
从"上网"说开去 1.上网就是请求数据 老师现在进行一个互联网原理的整体感知的教学,你注意,整体感知中,一些具体的细节,可能令你没有安全感(很多的知识盲点).没有关系,老师进行的是 ...
- CodeIgniter框架入门教程——第三课 URL及ajax
本文转载自:http://www.softeng.cn/?p=74 这节课讲一下CI框架的路由规则,以及如何在CI框架下实现ajax功能. 首先,先介绍CI框架的路由规则,因为CI框架是在PHP的基础 ...
- 第三十六课:如何书写一个完整的ajax模块
本课主要教大家如何书写一个完整的ajax模块,讲解的代码主要跟ajax有关,而jQuery的ajax模块添加了Deferred异步编程的机制,因此对ajax的理解难度增大,还是忽略掉.但是我要讲解的代 ...
- 第三十五课:Ajax详解
一个完整的Ajax请求: var xhr = new (self.XMLHttpRequest || ActiveXObject)("Microsoft.XMLHTTP"); ...
- 手把手教你写电商爬虫-第三课 实战尚妆网AJAX请求处理和内容提取
版权声明:本文为博主原创文章,未经博主允许不得转载. 系列教程: 手把手教你写电商爬虫-第一课 找个软柿子捏捏 手把手教你写电商爬虫-第二课 实战尚妆网分页商品采集爬虫 看完两篇,相信大家已经从开始的 ...
随机推荐
- XCode 遇到的问题
俗话说:工欲善其事必先利其器.抛弃了VS,投入XCode的怀抱.先不说两者的差距,还是先熟悉开发工具是关键.下面列出个人使用中遇到的一些问题. Problem1:修改Xcode字体颜色以及调整字体大小 ...
- LeetCode 22 Generate Parentheses(找到所有匹配的括号组合)
题目链接 : https://leetcode.com/problems/generate-parentheses/?tab=Description 给一个整数n,找到所有合法的 () pairs ...
- [原]rpm安装rpm-package报错:Header signature NOKEY 和 error: Failed dependencies:
以前经常遇到这个问题,一直未有记录,今天记录下来: 在安装rpm包的时候报错误如下: Question 1: warning: *.rpm: Header V3 DSA signature: NOKE ...
- Unity3D笔记十四 力
Unity中力的方式有两种:第一种为普通力,需要设定力的方向与大小:第二种为目标位置力,需要设定目标点的位置,该物体将朝向这个目标位置施加力. 1.案例 添加两个球体和一个立方体,另外还要给两个球体添 ...
- Redis学习资料整理
Redis学习资料: (1)Redis设计与实现 (2)十五分钟介绍 Redis数据结构 (3)redis安装 (4)redis指令手册中文版 Hiredis学习资料: (1)hiredis安装及测试 ...
- wordpress---page页面数据调用
在wordpress的开发中,会使用wordpress的的页面,那么页面数据该怎么调用呢? 拿到页面的 content: <?php if(have_posts()) : ?> <? ...
- 51单片机之IIC通信原理及软件仿真
关于IIC我觉这个博客里面说的已经够清楚了 如下图所示的写操作的时序图: 其实像这种通信协议的要求是很精确的,一点点不对都可能导致在实际工程中无法读取数据.我就是被一个应答位耽误了好久,还好最后被我发 ...
- javascript中top、clientTop、scrollTop、offsetTop的讲解(转载加总结)
scrollHeight: 获取对象的滚动高度. scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离 scrollTop:设置或获取位于对象最顶端和窗口中可见内容的最 ...
- HDU-2680 Choose the best route 单向边+反向dijkstra
https://vjudge.net/problem/HDU-2680 题意:以起始点 终点 长度 给出一个图,已知可以从w个起点出发,求从任一起点到同一个终点s的最短路径.注意是单向边.m<1 ...
- hive体系结构
1.什么是hive Hive是一个基于Hadoop的数据仓库,可以将结构化数据映射成一张表,并提供类SQL的功能,最初由Facebook提供,使用HQL作为查询接口.HDFS作为存储底层.mapRed ...