我有这种情况:入门隐藏表单域使用JSON使用列表中AngularJs
我的PHP文件的部分:
<form action="fechar_pedido.php" method="post" enctype="multipart/form-data" ng-controller="carrinhoQtdeController">
<?php
$json_data = array();
foreach($_SESSION['carrinho'] as $key => $value)
{
$json_array = array();
$prod_info = array_values($value);
$json_array += array($prod_info[0] . '-' . $prod_info[1]=>array("id" => $prod_info[0], "tamanho" => $prod_info[1], "qtde" => $prod_info[2], "classificacao" => intval($prod_info[3]), "id_depto" => intval($prod_info[4]),"id_categ" => intval($prod_info[5]),"id_subcateg" => intval($prod_info[6])));
array_push($json_data, $json_array);
}
$json_data = json_encode($json_data);
?>
<input type="hidden" ng-model="jsoncart" value="<?php echo $json_data; ?>" />
上面,我有填充数组与我目前的购物车产品的foreach,并以json格式列表转换该数组。
之后,我用这个json列表设置了一个隐藏表单域。我的想法是在我的角度函数中获得这个值,如下所述。
这里是我的隐藏字段的结果:
<input type="hidden" ng-model="jsoncart" value="[{"1-XGG":{"id":1,"tamanho":"XGG","qtde":4,"classificacao":7,"id_depto":1,"id_categ":1,"id_subcateg":4}},{"2-M":{"id":2,"tamanho":"M","qtde":1,"classificacao":4,"id_depto":1,"id_categ":1,"id_subcateg":4}}]" />
这里是我的角度文件的一部分:
var app = angular.module('myApp', []);
app.controller('carrinhoQtdeController', function($scope) {
$scope.bill = { total: 0, subtotal: 0 };
$scope.items = "";
$scope.param = "?jsoncart=" + $scope.jsoncart; <----- Here I try to get hidden field value !!!!
$http.get("./fetch_carrinho.php" + $scope.param)
.success(function(response){
$scope.items = response;
})
.error(function(error) {
alert(error);
$scope.carrinho = "error in fetching data";
});
var calculateTotals = function() {
var total = 0;
for (var i = 0, len = $scope.items.length; i < len; i++) {
total = total +
$scope.items[i].price *
$scope.items[i].quantity;
}
$scope.bill.total = total;
$scope.bill.subtotal = total - $scope.bill.discount;
};
});
在线指示,我尝试加入与jsoncart模型网址,但我无法得到它的价值。在隐藏字段中,我已经使用了“value”,“ng-value”,“ng-bind”,但我无法获得任何值。
所以,我的问题是如何获得隐藏的字段值?
谢谢, 马塞洛。
我想,你的设计方法并不好。无论如何,我假设一些报价问题..改变价值属性用单引号括起来,并尝试! – Asik 2015-02-10 18:59:53
我在$ scope.jsoncart中得到了“undefined”,''没有做任何修改。 顺便说一句,我在这里的接近并没有完成......它是解决方案的一部分,但我需要解决这个问题。转发... – Olivertech 2015-02-10 19:29:56
错误,您需要学习更多关于AngularJS的知识,对于像您这样的初学者,我推荐MongoDB,它更简单 – 2015-02-10 19:52:15