2017-04-12 44 views
0

Angular JS - 如何將JSON值轉換爲JSON密鑰?

var demoApp = angular.module('myApp', []); 
 
demoApp.controller('MyController', function($scope, $http) { 
 
    $scope.formData = {}; 
 
    $scope.formData.selectedTechnologies = {}; 
 

 
    $scope.checkSelected = function(object) { 
 
     return Object.keys(object).some(function(key) { 
 
      return object[key]; 
 
     }); 
 
    }; 
 

 
    $scope.technologies = [ 
 
     {id:1, name:'Angular JS'}, 
 
     {id:2, name:'PHP'}, 
 
     {id:3, name:'HTML'}, 
 
     {id:4, name:'JAVA'}, 
 
     {id:5, name:'CSS'}, 
 
     {id:6, name:'DOTNET'} 
 
    ]; 
 
    
 
    //$scope.formData.selectedTechnologies = {'Angular JS':true, 'HTML':true}; /* This is working fine */ 
 
    
 
    var myTech = {"myTechnology":["Angular JS","HTML"]}; /* This is dynamic value */ 
 
    $scope.formData.selectedTechnologies = myTech.myTechnology; 
 
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script> 
 

 

 
<body ng-app="myApp"> 
 
<h2>Technologies</h2> 
 
<div ng-controller="MyController"> 
 
<form name="projectForm" novalidate ng-submit="projectForm.$valid && submitForm()"> 
 
<div class="col-sm-3" ng-repeat="technology in technologies"> 
 
<div class="checkbox checkbox-info checkbox-inline"> 
 
<input type="checkbox" name="technology_name" ng-model="formData.selectedTechnologies[technology.name]" id="technology{{$index}}" ng-required="!checkSelected(formData.selectedTechnologies)" /> 
 
<label for="technology{{$index}}" ng-bind="technology.name"></label> 
 
<div class="col-lg-12" ng-show="projectForm.$submitted || projectForm.technology_name.$touched"> 
 
    <span ng-show="projectForm.technology_name.$error.required" class="text-danger">Select any technology.</span> 
 
</div> 
 
</div> 
 
</div> 
 
</form> 
 
</div> 
 
</body>

我已經發布了一些我的現有技術的上市。我想要默認選擇Angular JSHTML,它存在於我的myTech變量中。

如果我寫$scope.formData.selectedTechnologies = {'Angular JS':true, 'HTML':true};我得到正確的輸出。

請教我如何將["Angular JS","HTML"]轉換爲{"Angular JS":true,"HTML":true}

回答

2

要創建這樣的數組,你可以使用這個叫做reduce美麗的功能。

像這樣:

$scope.formData 
    .selectedTechnologies = myTech.myTechnology.reduce(function(arr, tech) { 
    arr[tech] = true; 
    return arr; 
    }, []); 

這裏的工作片段:

var demoApp = angular.module('myApp', []); 
 
demoApp.controller('MyController', function($scope, $http) { 
 
    $scope.formData = {}; 
 
    $scope.formData.selectedTechnologies = {}; 
 
    $scope.technologies = [{ 
 
     id: 1, 
 
     name: 'Angular JS' 
 
    }, 
 
    { 
 
     id: 2, 
 
     name: 'PHP' 
 
    }, 
 
    { 
 
     id: 3, 
 
     name: 'HTML' 
 
    }, 
 
    { 
 
     id: 4, 
 
     name: 'JAVA' 
 
    }, 
 
    { 
 
     id: 5, 
 
     name: 'CSS' 
 
    }, 
 
    { 
 
     id: 6, 
 
     name: 'DOTNET' 
 
    } 
 
    ] 
 

 
    var myTech = { 
 
    "myTechnology": ["Angular JS", "HTML"] 
 
    }; 
 
    $scope.formData 
 
    .selectedTechnologies = myTech.myTechnology.reduce(function(arr, tech) { 
 
    arr[tech] = true; 
 
    return arr; 
 
    }, []); 
 
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script> 
 

 

 
<body ng-app="myApp"> 
 
    <h2>Technologies</h2> 
 
    <div ng-controller="MyController"> 
 
    <div class="col-sm-3" ng-repeat="technology in technologies"> 
 
     <div class="checkbox checkbox-info checkbox-inline"> 
 
     <input type="checkbox" name="technology_name" ng-model="formData.selectedTechnologies[technology.name]" id="technology{{$index}}" ng-required="!checkSelected(formData.selectedTechnologies)" /> 
 
     <label for="technology{{$index}}" ng-bind="technology.name"></label> 
 
     </div> 
 
    </div> 
 
    </div> 
 
</body>

+0

謝謝tanmay。你的代碼工作正常。我有一點變化,但總體而言,您的代碼適合我的答案。我接受這個答案。再次感謝... – Chinmay235

1

使用地圖函數將您的數組轉換爲具有鍵值對的對象。

var demoApp = angular.module('myApp', []); 
 
demoApp.controller('MyController', function($scope, $http) { 
 
    $scope.formData = {}; 
 
    $scope.formData.selectedTechnologies = {}; 
 
    $scope.technologies = [ 
 
     {id:1, name:'Angular JS'}, 
 
     {id:2, name:'PHP'}, 
 
     {id:3, name:'HTML'}, 
 
     {id:4, name:'JAVA'}, 
 
     {id:5, name:'CSS'}, 
 
     {id:6, name:'DOTNET'} 
 
    ] 
 
    
 
    var myTech = {"myTechnology":["Angular JS","HTML"]}; 
 
    var defaultTechnologies ={} 
 
    defaultTechnologies = Object.assign(...myTech.myTechnology.map(d => ({[d]:true}))) 
 
    $scope.formData.selectedTechnologies = defaultTechnologies; 
 
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script> 
 

 

 
<body ng-app="myApp"> 
 
<h2>Technologies</h2> 
 
<div ng-controller="MyController"> 
 
<div class="col-sm-3" ng-repeat="technology in technologies"> 
 
<div class="checkbox checkbox-info checkbox-inline"> 
 
<input type="checkbox" name="technology_name" ng-model="formData.selectedTechnologies[technology.name]" id="technology{{$index}}" ng-required="!checkSelected(formData.selectedTechnologies)" /> 
 
<label for="technology{{$index}}" ng-bind="technology.name"></label> 
 
</div> 
 
</div> 
 
</div> 
 
</body>

+0

請描述你只是改變 – mplungjan

+0

您手動更改'var myTech = {「myTechnology」:{「Angular JS」:true,「HTML」:true}};'但是t他的價值是動態的。如何通過編程方式將'[「Angular JS」,「HTML」]'更改爲'{「Angular JS」:true,「HTML」:true}'? – Chinmay235

+0

@ Chinmay235修改了它。那是你在找什麼? –

0

你可以做類似如下:

var myTech = {"myTechnology":["Angular JS","HTML"]}; 
 
var myTechArr = myTech.myTechnology; 
 
var myTectObj = {}; 
 
myTechArr.forEach(function(item, i){ 
 
    myTectObj[item] = true; 
 
}); 
 
console.log(myTectObj);

4

無需轉換您的JSON對象

var myTech = { 
    "myTechnology": ["Angular JS", "HTML"] 
    }; 

只要改變你的$scope.checkSelected

這個

$scope.checkSelected = function(object) { 
     return $scope.formData.selectedTechnologies.includes(object.name); 
    }; 

和你的HTML這個

<input type="checkbox" name="technology_name" ng-model="formData.selectedTechnologies[technology.name]" id="technology{{$index}}" ng-checked="checkSelected(technology)" /> 

的ECMAScript 2016包括陣列

include方法DEMO FIDDLE

編輯:使用indexOf由@tanmay在評論中說

$scope.checkSelected = function(object) { 
     return $scope.formData.selectedTechnologies.indexOf(object.name) != -1; 
    }; 
+0

..這隻適用於現代瀏覽器(40+),不支持IE – tanmay

+0

在這種情況下,您可以添加polyfill或將其更改爲'indexOf'。這比操縱動態創建的數組更好,因爲它可以被使用,因爲它是 – Nishant123

+0

是的,好的舊'indexOf'將在不編碼時用於樂趣:D – tanmay