首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >上传前AngularJS图像预览显示先前选定的图像

上传前AngularJS图像预览显示先前选定的图像
EN

Stack Overflow用户
提问于 2015-12-07 23:10:45
回答 2查看 3K关注 0票数 1
代码语言:javascript
运行
复制
    myApp.directive('fileModel', ['$parse', function($parse) {
    return {
      restrict: 'A',
      link: function($scope, element, attrs) {
    var model = $parse(attrs.fileModel);
    var modelSetter = model.assign;
    element.bind('change', function(e) {
      $scope.$apply(function(e) {
        modelSetter($scope, element[0].files[0]);
      });
      $scope.setimage();
    });
  }

上面的代码是我的指令。

在函数$scope.setimage()中

代码语言:javascript
运行
复制
     $scope.setimage = function() {
  var file = $scope.myFile;
  var reader = new FileReader();
  reader.readAsDataURL(file);
  reader.onload = function(e) {
    $scope.ImageSrc = e.target.result;
  }
}

每当我选择文件时,

代码语言:javascript
运行
复制
  <img width= 250 height=350 ng-src="{{ImageSrc}}"/>
  <input type=`enter code here`"file" file-model="myFile"/>

预览立即不出现。当我选择第二次时,会出现先前选择的图像文件的预览。不知道是怎么回事。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-12-07 23:22:51

element.bind('change', ...不同,您可以在myFile上使用$scope.$watch,如下所示:

代码语言:javascript
运行
复制
$scope.$watch('$scope.myFile', function(e) {
  $scope.$apply(function(e) {
    modelSetter($scope, element[0].files[0]);
  });
  $scope.setimage();
});

请注意,需要定义$scope.myFile才能实现这一点,因此如果指令中没有定义它,则需要将其添加到控制器中。

票数 0
EN

Stack Overflow用户

发布于 2015-12-09 05:03:04

我为imagesrc分配添加了$scope.$apply,并立即更新了图像。

代码语言:javascript
运行
复制
   $scope.setimage = function() {
   var file = $scope.myFile;
   var reader = new FileReader();
   reader.readAsDataURL(file);
   reader.onload = function(e) {
     $scope.$apply(function(){
      $scope.ImageSrc = e.target.result;
    });  }
   }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34145096

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档