我想做的是我正在尝试做一个购物车,它不会在你每次点击一个项目时重新加载页面,而是在会话中保存所选的项目。
因此,在用户单击“add”之后,我将把值添加到会话中,然后在json数组中解析会话值,并将整个“产品列表”附加到购物车中。
问题是,由于某种原因,它为data.dados[0].id_prod打印的是“Undefined”,而它应该打印的是产品的ID。
这是我的控制器
//get the ajax ‘get’ ...
if (isset($_GET[‘id_prod’]) && !empty($_GET[‘id_prod’]) && isset($_GET[‘qnt’]) && !empty($_GET[‘qnt’])) {
$ma = $this->loja_model->add_carrinho($_GET[‘id_prod’], $_GET[‘qnt’]);
$carr = $this->loja_model->list_carrinho();
if ( isset($carr) && !empty($carr) ) {
$array[‘data’][‘dados’]=$carr[0];
$array[‘data’][‘valor’]=$carr[1];
echo json_encode($array);
}
}
在调用$. AJAX 之后打印这个json对象:
{“data”:
{“dados”:
[
{“id_prod”:“1”,“id_cat”:“4”,“produto”:“Barco Velho”,“descricao”:“Barco de madeira tipo canoa.”,“valor”:“100.00”,“custo”:“0”,“qnt”:49},
{“id_prod”:“2”,“id_cat”:“1”,“produto”:“Fusca 68”,“descricao”:“Raridade. Impec?vel. Roda. Trio. Som. Estepe original.”,“valor”:“4000.00”,“custo”:“0”,“qnt”:11},
{“id_prod”:“3”,“id_cat”:“2”,“produto”:“MonoMoto”,“descricao”:“Moto de uma roda s?”,“valor”:“18000.00”,“custo”:“0”,“qnt”:2}
],
“valor”:84900}
}
这是我的JS文件:
$.ajax({
url: ‘http://mdk-store.com/loja/index.php/lojavirtual/index’,
data: data_prod,
type: ‘GET’,
dataType: ‘json’,
async: true,
success: function(data) {
window.alert(data[0].id_prod);
}
});
1条答案
按热度按时间zhte4eai1#
根据JSON,您应该使用:
data.data.dados[0].id_prod
.为了以预期的方式访问数据,JSON需要如下所示: