2016-09-13 93 views
0

JSONAngularJS動態添加和刪除DIV不工作

{ 
    "id": "1", 
    "name": "T-Shirt", 
    "status": "1", 
    "product_attributes": [{ 
    "id": 1, 
    "label": "Size", 
    "choices": [{ 
     "text": "Size 30", 
     "value": "Size 30", 
     "isSelected": false, 
     "price": "$100.00" 
    }, { 
     "text": "Size 32", 
     "value": "Size 32", 
     "isSelected": true, 
     "price": "$100.00" 
    }, { 
     "text": "Size 34", 
     "value": "Size 34", 
     "isSelected": false, 
     "price": "$100.00" 
    }, { 
     "text": "Size 36", 
     "value": "Size 36", 
     "isSelected": false, 
     "price": "$100.00" 
    }] 
    }, { 
    "id": 2, 
    "label": "Color", 
    "choices": [{ 
     "text": "Denim", 
     "value": "Denim", 
     "isSelected": true, 
     "price": "$0.00" 
    }, { 
     "text": "Black", 
     "value": "Black", 
     "isSelected": false, 
     "price": "$5.00" 
    }, { 
     "text": "Brown", 
     "value": "Brown", 
     "isSelected": false, 
     "price": "$2.00" 
    }], 
    }] 
} 

HTML

<div ng-repeat="attributes in product.product_attributes"> 
    <h3>{{attributes.name}}</h3> 
    <div class="choice"> 
     <h2>Choices</h2> 
     <div ng-repeat="choices in attributes.choices"> 
      <div class="form-group"> 
       <input type="text" ng-model="choices.value" class="form-control"> 
       <a href="" ng-click="addField()">Add</a> 
       <a href="" ng-click="removeField($index)">Remove</a> 
      </div> 
     </div> 
    </div> 
</div> 

JS

$scope.attributes = {choices: [{label:'1'}]}; 

$scope.getProductAndAttributes = function() { 
     $http({ 
      method: 'POST', 
      url: 'products/get_product_details.json', 
      dataType: "json", 
      data: {'id': $stateParams.product_id}, 
      headers: {'Content-Type': 'application/x-www-form-urlencoded'} 
     }).success(function(data) { 
      $scope.product_name = data.name; 
      $scope.product_attributes = data.product_attributes; 
     }); 
    }; 

$scope.addField = function() { 
    var newItemNo = $scope.attributes.choices.length + 1; alert(newItemNo); 
     $scope.attributes.choices.push({'label': 'choice' + newItemNo}); 
}; 
$scope.removeField = function(i) { 
    $scope.attributes.choices.splice(i, 1); 
}; 
if ($stateParams.product_id) { 
    $scope.getProductAndAttributes(); 
} 

上面我已經發布我的卡斯特省略代碼。但我的AddRemove不起作用。請檢查我的JSON我從我的數據庫中獲得的這些數據。

請幫幫我。

+1

「沒有工作「是相當普遍的。我們不知道您希望添加或刪除操作。我會說你有'$ scope.product_attributes'和'$ scope.attributes',這很混亂,你指向'$ scope.attributes.choices',但'choices'是單個'attribute'的屬性,而不是陣列。你會得到什麼'$ scope.attributes [0] .choices'或其他什麼。 –

回答

2

1)你在JSON裏面有語法錯誤,在....."isSelected":false,"price":"$2.00"}],附近刪除了逗號。

2)dinamically編輯產品對象將它傳遞給函數,而不是使用$scope,同樣用於去除

3)你不需要更新數組長度手動,其通過推功能完成的。

var app = angular.module("app", []) 
 
    .controller("ctrl", function($scope) { 
 
    $scope.product = JSON.parse('{"id":"1","name":"T-Shirt","status":"1","product_attributes":[{"id":1,"label":"Size","choices":[{"text":"Size 30","value":"Size 30","isSelected":false,"price":"$100.00"},{"text":"Size 32","value":"Size 32","isSelected":true,"price":"$100.00"},{"text":"Size 34","value":"Size 34","isSelected":false,"price":"$100.00"},{"text":"Size 36","value":"Size 36","isSelected":false,"price":"$100.00"}]},{"id":2,"label":"Color","choices":[{"text":"Denim","value":"Denim","isSelected":true,"price":"$0.00"},{"text":"Black","value":"Black","isSelected":false,"price":"$5.00"},{"text":"Brown","value":"Brown","isSelected":false,"price":"$2.00"}]}]}'); 
 

 
    $scope.addField = function(i, attributes) { 
 
     attributes.choices.splice(i+1, 0, { 
 
     'label': 'choice' + attributes.choices.length+1 
 
     }); 
 
    }; 
 
    $scope.removeField = function(i, attributes) { 
 
     attributes.choices.splice(i, 1); 
 
    }; 
 
    });
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script> 
 
<div ng-controller="ctrl" ng-app="app"> 
 
    <div ng-repeat="attributes in product.product_attributes"> 
 
    <h3>{{attributes.name}}</h3> 
 
    <div class="choice"> 
 
     <h2>Choices</h2> 
 
     <div ng-repeat="choices in attributes.choices"> 
 
     <div class="form-group"> 
 
      <input type="text" ng-model="choices.value" class="form-control"> 
 
      <a href="" ng-click="addField($index, attributes)">Add</a> 
 
      <a href="" ng-click="removeField($index, attributes)">Remove</a> 
 
     </div> 
 
     </div> 
 
    </div> 
 
    </div> 
 
</div>

+0

謝謝你的回答 – Chinmay235

0

這裏的工作plunk

有太多的變化,他們在這裏勾勒而是總結你需要確定你想通過一些關鍵的價值,而不是通過$索引添加或刪除數組元素,像這樣:

$scope.removeField = function(attributeId, choiceValue) { 
    var attributes = $scope.product.product_attributes; 
    for (var i = 0; i < attributes.length; i++) { 
     if (attributes[i].id === attributeId) { 
     var attribute = attributes[i]; 
     var choices = attribute.choices; 
     for (var j = 0; j < choices.length; j++) { 
      if (choices[j].value === choiceValue) { 
      choices.splice(j, 1); 
      return; 
      } 
     } 
     } 
    } 
    };