如何从 firebase 存储绑定 angularjs 中的图像

How to bind image in angularjs from firebase storage

如何在来自 Firebase 存储参考的 angularjs 视图中显示图像? 我可以在控制台中打印 url 但无法在视图中访问。

服务代码

function getImageUrl(image) {
        var url;
        var pathReference = firebaseDataService.images.child(image);
        return pathReference.getDownloadURL().then(function(url) {
           return url;                
        }).catch(function(error) {
            // Handle any errors
        });         
    }

控制器代码

$scope.getImageUrl = function(image) {
var imageUrl;
    var imageUrl = Service.getImageUrl(image).then(function(url) {  
          imageUrl = url;
          console.log(url);
          return imageUrl;
    });
   return imageUrl;
}

查看

 <div ng-repeat="category in categories">
  <img src="{{getImageUrl(category.image)}}">
 </div>

在 src 属性中使用像 {{hash}} 这样的 Angular 标记不能正常工作:浏览器将从 URL 中获取文字文本 {{hash}} 直到 Angular 替换 {{hash}} 中的表达式。 ngSrc 指令解决了这个问题。

<img ng-src="{{getImageUrl(category.image)}}">

当您检索类别时,您可以遍历类别并检索每个图像,将其存储在不同的范围对象中并在您的视图中使用它。

$scope.images = {};

categoriesSnapshot.forEach(function(category){
    Service.getImageUrl(category.val().image).then(function(url) {  
          $scope.images[category.key] = url;
    }); 
});

在你的HTML中:

<div ng-repeat="(key, val) in categories">
    <img src="{{images[key]}}">
</div>