Ajax调用返回json,xml数据类型(0517--pm)
一、返回Json型数据:
1.主页面
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>无标题文档</title>
- <script src="../jquery-1.11.2.min.js"></script>
- </head>
- <body>
- <select id="sel">
- </select>
- </body>
- <script type="text/javascript">
- $(document).ready(function(e) {
- $.ajax({
- url:"ChuLi.php",
- dataType:"JSON",
- success: function(data){
- //alert(data);
- var str = "";
- for(var k in data)
- {
- str+="<option value='"+data[k][0]+"'>"+data[k][1]+"</option>";
- }
- $("#sel").html(str);
- }
- });
- });
- </script>
- </html>
2.处理页面
- <?php
- include("../DBDA.class.php");
- $db = new DBDA();
- $sql = "select * from Nation";
- $attr = $db->Query($sql);
- echo json_encode($attr);
- ?>
3.运行结果
二、返回xml数据
XML:页面之间传递数据,跨平台传递
HTML:超文本标记语言,核心标签
1. 什么是XML?
XML(eXtensible Markup Language)即可扩展标记语言,它与HTML一样,都是SGML(Standard Generalized Markup Language,标准通用标记语言)。Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具。扩展标记语言XML是一种简单的数据存储语言,使用一系列简单的标记描述数据,而这些标记可以用方便的方式建立,虽然XML占用的空间比二进制数据要占用更多的空间,但XML极其简单易于掌握和使用。
XML与Access,Oracle和SQL Server等数据库不同,数据库提供了更强有力的数据存储和分析能力,例如:数据索引、排序、查找、相关一致性等,XML仅仅是展示数据。事实上XML与其他数据表现形式最大的不同是:他极其简单。这是一个看上去有点琐细的优点,但正是这点使XML与众不同。
XML的简单使其易于在任何应用程序中读写数据,这使XML很快成为数据交换的唯一公共语言,虽然不同的应用软件也支持其它的数据交换格式,但不久之后他们都将支持XML,那就意味着程序可以更容易的与Windows、Mac OS, Linux以及其他平台下产生的信息结合,然后可以很容易加载XML数据到程序中并分析他,并以XML格式输出结果。
2. XML特点:
1.标签名可以自己定义
2.有且只有一个根
3.大小写敏感
4.标签必须完整
3. XNL书写形式:
- <xml version='1.0'>
- <Nation>
- <one>
- <Code>n001</Code>
- <name>汉族</name>
- </one>
- <two>
- <code>n002</code>
- <name>苗族</name>
- </two>
- </Nation>
4. 例子:同上面Json的例子
1.主页面
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>无标题文档</title>
- <script src="../jquery-1.11.2.min.js"></script>
- </head>
- <body>
- <select id="sel"></select>
- </body>
- <script type="text/javascript">
- $(document).ready(function(e) {
- $.ajax({
- url:"chulixml.php",
- dataType:"XML",
- success:function(data){
- var ch = $(data).find("nation").children();
- var str = "";
- for(var i=0;i<ch.length;i++)
- {
- var code = $(ch[i]).find("code").text();
- var name = $(ch[i]).find("name").text();
- str+="<option value='"+code+"'>"+name+"</option>";
- }
- $("#sel").html(str);
- }
- });
- });
- </script>
- </html>
2. 处理页面
- <?php
- include("../DBDA.class.php");
- $db = new DBDA();
- $sql = "select * from nation";
- $attr = $db->Query($sql);
- echo "<?xml version='1.0'?>";
- echo "<nation>";
- foreach($attr as $k=>$v)
- {
- echo "<shuju{$k}>";
- echo "<code>{$v[0]}</code>";
- echo "<name>{$v[1]}</name>";
- echo "</shuju{$k}>";
- }
- echo "</nation>";
3.运行结果
三、Ajax调用返回Json数据,封装类
- //Ajax调用返回JSON
- public function JsonQuery($sql,$type=1,$db="mydb")
- {
- //定义数据源
- $dsn = "mysql:dbname={$db};host={$this->host}";
- //造pdo对象
- $pdo = new PDO($dsn,"{$this->uid}","{$this->password}");
- //准备执行SQL语句
- $st = $pdo->prepare($sql);
- //执行预处理语句
- if($st->execute())
- {
- if($type==1)
- {
- $attr = $st->fetchAll(PDO::FETCH_ASSOC);
- return json_encode($attr);
- }
- else
- {
- if($st)
- {
- return "OK";
- }
- else
- {
- return "NO";
- }
- }
- }
- else
- {
- echo "执行失败!";
- }
- }
Ajax调用返回json,xml数据类型(0517--pm)的更多相关文章
- dbda封装类(包括:返回二维数组、Ajax调用返回字符串、Ajax调用返回JSON)
<?php class DBDA { public $host = "localhost"; public $uid = "root"; public $ ...
- Ajax--json(Ajax调用返回json封装代码、格式及注意事项)
Ajax调用json封装代码<dbda.php>: //Ajax调用返回JSON public function JsonQuery($sql,$type=1,$db="mydb ...
- jquery ajax调用返回json格式数据处理
Ajax请求默认的都是异步的 如果想同步 async设置为false就可以(默认是true) var html = $.ajax({ url: "some.php", async: ...
- SpringMVC 避免IE执行AJAX时,返回JSON出现下载文件
<?xml version="1.0" encoding="UTF-8"?> <!-- SpringMVC配置文件 --> <be ...
- spring mvc 避免IE执行AJAX时,返回JSON出现下载文件
<!-- 避免IE执行AJAX时,返回JSON出现下载文件 --> <bean id="mappingJacksonHttpMessageConverter" c ...
- php返回json,xml,JSONP等格式的数据
php返回json,xml,JSONP等格式的数据 返回json数据: header('Content-Type:application/json; charset=utf-8'); $arr = a ...
- 在使用Ajax请求返回json数据的时候IE浏览器弹出下载保存对话框的解决方法
在使用Ajax请求返回json数据的时候IE浏览器弹出下载保存对话框的解决方法 最近在做一个小东西,使用kindeditor上传图片的时候,自己写了一个上传的方法,按照协议规则通过ajax返回json ...
- AJAX请求,返回json进行页面绑值
AJAX请求,返回json进行页面绑值 后台 controller @RequestMapping(value = "backjson.do",method=RequestMeth ...
- Struts2+Jquery实现ajax并返回json类型数据
来源于:http://my.oschina.net/simpleton/blog/139212 摘要 主要实现步骤如下: 1.JSP页面使用脚本代码执行ajax请求 2.Action中查询出需要返回的 ...
随机推荐
- mysql优化 - mysql 的 hint
FORCE INDEX 强制索引 只使用建立在field1上的索引,而不使用其它字段上的索引. SELECT * FROM table1 FORCE INDEX (field1) IGNORE IND ...
- IOS动画总结
IOS动画总结 一.基本方式:使用UIView类的UIViewAnimation扩展 + (void)beginAnimations:(NSString *)animationID context ...
- 安卓4.2原生rom状态栏显示运营商
前言:要调整状态栏布局,需反编译systemui.apk.单卡机修改status_bar.xml和signal_cluster_view.xml,双卡机修改gemini_status_bar.xml和 ...
- How systems researchers build systems
Define the problem >>Identify the constraints and abstract problem propose solution:simple ide ...
- jboss部署应用
简单的部署应用. 第一种方法是直接写JSP代码,然后放到指定的WAR文件夹中. 第二种,是同时META-INF下的application.xml文件,然后用JAR -CF编成WAR,再集合JSP形成E ...
- delphi 程序窗体及控件自适应分辨率(通过ComponentCount遍历改变字体大小以及上下左右)
unit untFixForm; interface uses Classes, SysUtils, Controls, Forms; type TFontedControl = class(TCon ...
- VS2008 运行VC\Bin下的link.exe, cl.exe, lib.exe提示找不到mspdb80.dll的解决方法
天在用link.EXE的LIB命令生成用于连接(LINK)使用的lib文件时提示:找不到mspdb80.dll. 原因:Microsoft Visual Studio\VC\Bin\下没有 “msob ...
- 【HDOJ】4515 小Q系列故事——世界上最遥远的距离
简单题目,先把时间都归到整年,然后再计算.同时为了防止减法出现xx月00日的情况,需要将d先多增加1,再恢复回来. #include <cstdio> #include <cstri ...
- COJ 0995 WZJ的数据结构(负五)区间操作
WZJ的数据结构(负五) 难度级别:C: 运行时间限制:1000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 请你设计一个数据结构,完成以下功能: 给定一个大小为 ...
- 笔记:java并发编程实践1
Java 5.0 adds ConcurrentHashMap, a replacement for synchronized hash-based Map implementations, and ...