我正在尝试使用从模态返回的数据设置图像源。这是一个ng-repeat循环:
- <div id="divNetworkGrid">
- <div id="{{network.id}}" ng-repeat="network in networks">
- <span>
- <table>
- <tr>
- <td class="imgContainer">
- <img ng-src="{{ ('assets/img/networkicons/'+ network.actual + '.png') ||
- 'assets/img/networkicons/default.png' }}"/>
- </td>
- </tr>
- </table>
- </span>
- </div>
- </div>
显然,当network.actual model属性返回为null时,我想填充default.png。但是我的代码没有拿起默认的图像,尽管第一个图像在可用的时候很好。
我确定这是一些语法问题,但不能弄清楚是什么问题。
有趣的方式使用ng-src。我还没有测试过这个表达方式的处理方式,但是我建议做一个比较稳定的方法:
- <img ng-src="{{ networkIcon }}" />
在你的控制器中:
- $scope.networkIcon = network.actual ? 'assets/img/networkicons/' + network.actual + '.png' : 'assets/img/networkicons/default.png';
编辑:只是为了澄清,我不是建议最好的方法是将图像源直接绑定到范围,而是将图像后备逻辑移动到视图之外。在我的应用程序中,我经常在检索数据或服务器本身的服务中发送图像URL,以便客户端只需要担心单个属性。
编辑地址中继器:
- angular.forEach($scope.networks,function(network) {
- network.icon = network.actual ? 'assets/img/networkicons/' + network.actual + '.png' : 'assets/img/networkicons/default.png';
- });
- <tr ng-repeat="network in networks">
- <td><img ng-src="{{ network.icon }}" /></td>
- </tr>