cakephp jquery ajax json

简介

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。Cakephp1.2提供了对JSON的内置支持,主要体现在两个特殊的方法:

Router::parseExtensions() 和 JavascriptHelper::object()

目标

我们要通过JQuery的$.getJSON方法,获取Cakephp服务端的JSON数据,URL可能是这个样子
1.http://localhost/posts/index.json

如何完成?

首先,要让Cakephp启用JSON的扩展名解析

编辑/config/routes.php,添加
1.Router::parseExtensions(’json’);

然后,为JSON设置Content-type

编辑app_controller.php,添加

var $components = array('RequestHandler');
function beforeFilter() {
$this->RequestHandler->setContent('json', 'text/x-json');
parent::beforeFilter();
}

RequestHandler的setContent方法,可以使json的扩展名使用特定的layout和视图,就像下面的代码

下面,为你的JSON数据创建一个layout

创建/layouts/json/default.ctp的代码

<?php
header("Pragma: no-cache");
header("Cache-Control: no-store, no-cache, max-age=0, must-revalidate");
header('Content-Type: text/x-json');
header("X-JSON: ".$content_for_layout);

echo $content_for_layout;
?>

注意:

在使用RequestHandler的setContent方法后,Cakephp会自动解析json扩展名的访问并且会默认使用

/layouts/json/default.ctp解析json,如果不存在这个layout的话,会出现 未找到layout 错误.

x-json头可以被prototype.js将返回的数据自动解析为JSON对象

下面创建我们的JSON视图

创建/views/posts/json/index.ctp的代码 (注意加粗的部分)

< ?php
echo $javascript->object($aPosts);
?>

同样的json也有自己的视图文件,简单理解就是,在你的控制器视图下的json文件夹,建立同名的视图文件.

控制器中的代码

function index() {

Configure::write('debug',0); //不加这一句 jquery获取 json数据时 无法获取 默认的debug页面会破坏json的数据结构,切记一定要加上

$this->set('aPosts', $this->Post->findAll());
}

在JQuery中使用

假如我们的返回值类似下面这样

Array
(
[0] => Array
(
[Post] => Array
(
[id] => 1
[user_id] => 54
[subject] => augue scelerisque mollis.
[body] => tristique senectus et netus et malesuada fames ac turpis egestas. Fusce aliquet magna
[created] => 2009-10-29 21:15:51
)

)

[1] => Array
(
[Post] => Array
(
[id] => 2
[user_id] => 81
[subject] => purus, in molestie tortor nibh
[body] => elit. Nulla facilisi. Sed neque. Sed eget lacus. Mauris non dui nec urna suscipit nonummy.
[created] => 2009-08-01 06:57:03
)

)

)

我们可以这样使用JSON数据

$.getJSON("http://localhost/posts/index.json", function(json){
alert(json[0].Post.subject);
alert(json[1].Post.subject);
});

可以看到,我们可以直接使用由json返回的数据,而不用做任何转换.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值