中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

AngularJS怎么實現圖片上傳和預覽功能的方法分析

發布時間:2021-04-21 10:56:27 來源:億速云 閱讀:414 作者:小新 欄目:web開發

小編給大家分享一下AngularJS怎么實現圖片上傳和預覽功能的方法分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

js的作用是什么

1、能夠嵌入動態文本于HTML頁面。2、對瀏覽器事件做出響應。3、讀寫HTML元素。4、在數據被提交到服務器之前驗證數據。5、檢測訪客的瀏覽器信息。6、控制cookies,包括創建和修改等。7、基于Node.js技術進行服務器端編程。

html5原生方法

先看一下html5原生方法上傳和預覽圖片的實現:

// <img id="img-preview">
var imgPreview = document.getElementById("img-preview");
// <input id="img-input" type="file">
var imgInput= document.getElementById("img-input");
imgInput.addEventListener("change", function(e){
 var imgFile = e.target.files[0]; // 獲取上傳的圖片
 var reader = new FileReader();
 reader.readAsDataURL(imgFile ); // 將圖片轉成dataUri
 reader.onload = function(e) {
  imgPreview.src = e.target.result; //更新圖片鏈接
 }
});

我們看到,需要用到onchange事件來獲得上傳的文件,當項目使用上angularjs時,很自然的,我們想到了ng-change指令,然而不幸的是,在angularjs中,<input type="file">不支持ng-model和ng-change指令(附錄1),這就使得文件上傳變得有些復雜了。

angularjs方法

這里使用開源的 angular-file-upload 模塊來實現,步驟如下:

1、安裝 angular-file-upload 模塊

bower install angular-file-upload --save

2、添加到應用依賴

var app = angular.module('my-app', [
  'angularFileUpload'
]);

3、HTML代碼

<!--文件上傳指令-->
<input type="file" nv-file-select="" uploader="uploader" />
<!--圖片預覽-->
<img id="img-preview" ng-src="{{iconUrl}}">

這里,nv-file-select=""表示使用angular-file-upload模塊的文件選擇方式上傳,參考官方例子

4、controller代碼

.controller('AppController', ['$scope', 'FileUploader', function($scope, FileUploader) {
    var uploader = $scope.uploader = new FileUploader({
      url: 'upload.php' //換成自己的上傳地址,本地演示不換也行
    });
    uploader.onAfterAddingFile = function(fileItem) {
      var reader = new FileReader();
      reader.addEventListener("load", function (e) {
        //文件加載完之后,更新angular綁定
        $scope.$apply(function(){
          $scope.iconUrl = e.target.result;
        });
      }, false);
      reader.readAsDataURL(fileItem._file);
    };
}]);

可以看到,我們通過onAfterAddingFile回調函數獲得所選的圖片文件,接下來把圖片文件轉成datauri,再更新<img>標簽的src屬性即可。

值得注意的是,我們把“更新<img>標簽的src屬性”這個任務放到了$scope.$apply方法中執行,這是因為在angular框架外部(如在瀏覽器DOM事件中, setTimeout, XHR 或者 第三方框架中)更新數據,angular是不會同步更新綁定的。這點可以參考angular $apply reference

以上是“AngularJS怎么實現圖片上傳和預覽功能的方法分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

清远市| 鄂托克前旗| 安平县| 南岸区| 武鸣县| 宜黄县| 清苑县| 潢川县| 汽车| 丹江口市| 冀州市| 郎溪县| 忻城县| 卓尼县| 齐齐哈尔市| 平安县| 宕昌县| 抚宁县| 黎城县| 襄垣县| 满城县| 阿拉尔市| 盖州市| 体育| 陕西省| 洛扎县| 当雄县| 涪陵区| 孙吴县| 巍山| 綦江县| 集贤县| 河北省| 工布江达县| 曲麻莱县| 类乌齐县| 武宁县| 清新县| 湖州市| 绵竹市| 额尔古纳市|