2016-03-23 5 views
1

Ich habe ein Problem mit ng-style mit ng-repeat.AngularJS und ng-style mit ng-repeat

Dies ist mein Code:

<div style="display:table-row" ng-repeat="row in Data.Communications" id="{{row.Guid}}"> 
    <div style="display:table-cell;"> 
     <img ng-src="{{row.Path}}" ng-show="row.Path" ng-style="row.Style" /> 
     <i class="{{row.Icon}}" ng-show="row.Icon" ng-style="row.Style"></i> 
    </div> 
</div> 

Dies ist die JSON (lasteten Server-Seite von einer DB):

$scope.Data: {"LastUpdate":"23/03/2016 11:45","Communications":[{"Guid":"2","Path":null,"Icon":"fa fa-warning","Style":"{'color':'#ffff00'}"},{"Guid":"1","Path":null,"Icon":"fa fa-warning","Style":"{'color':'#ffff00'}"},{"Guid":"3","Path":"/images/blink_yellow.gif","Icon":null,"Style":"{'width':'15px', 'height':'15px'}"}]} 

Der "Style" ist mein Element nicht angewandt. Könnte mir jemand helfen, dieses Problem zu lösen?

Antwort

0

Grundsätzlich haben Sie strigified JSON, nicht analysieren zuweisen es vor dem ng-style

ng-style="doParseToJson(row.Style)" 

-Code

$scope.doParseToJson = function(style){ 
    return JSON.parse(style); 
} 

außerdem sicher Antwort machen sollte mit " Doppel qoutes statt einfachen Anführungszeichen wickeln werden wie '{"color":"#ffff00"}', um es für das Parsen des JSON gültig zu halten.