Angular使用 ng-img-max 调整浏览器中的图片的示例代码


Posted in Javascript onAugust 17, 2017

你想在Angular应用程序中进行图片上传,是否想在图片上传之前在前端限制上传图片的尺寸?ng2-img-max模块正是你所要的! ng2-img-max模块会使用web sorkers 进行图片大小的计算,并驻留在主线程中。

我们来看看他的用途:

安装

首先,使用npm 或 Yarn安装模块:

$ npm install ng2-img-max blueimp-canvas-to-blob --save

# or Yarn :
$ yarn add ng2-img-max blueimp-canvas-to-blob

blueimp-canvas-to-blob是一个polyfill,以便canvas.toBlob()可以在Safari和旧版本的Internet Explorer等浏览器上使用。

将polyfill脚本包含在项目中。 如果您使用Angular CLI,您可以将脚本添加到.angular-cli.json文件中:

//: .angular-cli.json

...
"scripts": [
 "../node_modules/blueimp-canvas-to-blob/js/canvas-to-blob.min.js"
],
//...

将脚本添加到Angular CLI配置后,您将需要重新启动本地服务。

现在我们将模块导入应用模块或功能模块:

//: app.module.ts

//...
import { Ng2ImgMaxModule } from 'ng2-img-max';

@NgModule({
 declarations: [ AppComponent ],
 imports: [
  //...
  ng2ImgMaxModule
 ],
 providers: [],
 bootstrap: [ AppComponent ]
})
export class AppModule {}

最后,ng2-img-max服务可以导入并注入到这样的组件中:

import { Component } from '@angular/core';

import { Ng2ImgMaxService } from 'ng2-img-max';

@Component({ ... })
export class AppComponent {
 constructor(private ng2ImgMax: Ng2ImgMaxService ) {}
}

使用

我们添加一个File文件输入框到组件的模板中,像这样:

<input type='file' (change)="onImageChange($event)" accept="image/*" />

在组件类中添加方法onImageChange, 它将会限制图片的宽高为:400px,300px:

updateImage: Blob;

constructor(private ng2ImgMax: Ng2ImgMaxService) {}

onImageChange(event){
 let image = event.target.files[0];
 
 this.ng2ImgMax.resizeImage(image,400,300).subscribe(result=> {
  this.uploadImage = result;
 },
 error=> {
  console.log('error:',error);
 })
}

如果您有多个图像需要一次性调整大小,请改用resize方法,并将图片文件数组作为第一个参数传入。

结果是Blob类型,但是如果需要,可以使用File构造函数将其转换为正确的文件:

//: app.component.ts

uploadedImage: File;
constructor(private ng2ImgMax: Ng2ImgMaxService) {}
onImageChange(event){
 let image = event.target.files[0];
 
 this.ng2ImgMax.resizeImage(image,400,300).subscribe(result=> {
  this.uploadedImage = new File([result],result.name);
 },
 error=> {
  console.log('error',error);
 })
}

您现在可以将文件上传到您的后端。 不要忘记在后端做好验证,因为这里的内容会阻止一些用户将超大或非图像文件直接上传到后端。

只限制宽度或高度

假设您只想将高度限制为300px,并相应调整宽度,以保持宽高比相同。 只要设置任何一阀值到10000:

//...
onImageChange(event) {
 let image = event.target.files[0];
 this.ng2ImgMax.resizeImage(image,10000,300).subscribe(result=> {
  this.uploadedImage = new File([result],result.name);
 },
 error=> {
  console.log('error:',error);
 });
}

压缩代替Resizing

您还可以使用compress或compressImage方法执行有损压缩,而不是调整图像大小。 只需传递最大值(兆字节)。 你显然想要运行一些测试,看看你想要走多远的几个小时,同时保持图像看起来很好。

在以下示例中,我们将生成的图像限制为大约75Kb:

onImageChange(event) {
 let image = event.target.files[0];

 this.ng2ImgMax.compressImage(image, 0.075).subscribe(
  result => {
   this.uploadedImage = new File([result], result.name);
   this.getImagePreview(this.uploadedImage);
  },
  error => {
   console.log('? Oh no!', error);
  }
 );
}

图片预览

您可能想要预览要上传到用户的图像。 您可以使用FileReader对象执行此操作。 您还需要使用Angular的DomSanitizer来使其信任使用FileReader对象创建的base64编码数据URI:

现在,我们的组件内容是这样的。组件中有趣的新方法是getImagePreview:

//: app.component.ts

import { Component } from '@angular/core';
import { Ng2ImgMaxService } from 'ng2-img-max';
import { DomSanitizer } from '@angular/platform-browser';

@Component({ ... })
export class AppComponent {
 uploadedImage: File;
 imagePreview: string;

 constructor(
  private ng2ImgMax: Ng2ImgMaxService,
  public sanitizer: DomSanitizer
 ) {}

 onImageChange(event) {
  let image = event.target.files[0];

  this.ng2ImgMax.resizeImage(image, 10000, 375).subscribe(
   result => {
    this.uploadedImage = new File([result], result.name);
    this.getImagePreview(this.uploadedImage);
   },
   error => {
    console.log('? Oh no!', error);
   }
  );
 }

 getImagePreview(file: File) {
  const reader: FileReader = new FileReader();
  reader.readAsDataURL(file);
  reader.onload = () => {
   this.imagePreview = reader.result;
  };
 }
}

在我们的模板中,我们可以使用sanitizer来显示如图像:

//: app.component.html

<img
  *ngIf="imagePreview"
  [src]="sanitizer.bypassSecurityTrustUrl(imagePreview)">

这就是它的全部! 您还可以查看同一作者的ng2-img-tools包,以获得更多的浏览器端图像处理(如裁剪)。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
window.location不跳转的问题解决方法
Apr 17 Javascript
js实现prototype扩展的方法(字符串,日期,数组扩展)
Jan 14 Javascript
很棒的Bootstrap选项卡切换效果
Jul 01 Javascript
Bootstrap作品展示站点实战项目2
Oct 14 Javascript
js实现一键复制功能
Mar 16 Javascript
整理关于Bootstrap表单的慕课笔记
Mar 29 Javascript
Vue如何引入远程JS文件
Apr 20 Javascript
详解vue.js的事件处理器v-on:click
Jun 27 Javascript
自己动手封装一个React Native多级联动
Sep 19 Javascript
CKeditor富文本编辑器使用技巧之添加自定义插件的方法
Jun 14 Javascript
小程序中英文混合排序问题解决
Aug 02 Javascript
浅析vue-router实现原理及两种模式
Feb 11 Javascript
Canvas放置反弹效果随机图形(实例)
Aug 17 #Javascript
js实现方块上下左右移动效果
Aug 17 #Javascript
JavaScript中一些特殊的字符运算
Aug 17 #Javascript
在 Angular 中使用Chart.js 和 ng2-charts的示例代码
Aug 17 #Javascript
JS 中LocalStorage和SessionStorage的使用
Aug 17 #Javascript
jQuery的时间datetime控件在AngularJs中的使用实例(分享)
Aug 17 #jQuery
详解JS中的柯里化(currying)
Aug 17 #Javascript
You might like
php smarty的预保留变量总结
2008/12/04 PHP
PHP 基于Yii框架中使用smarty模板的方法详解
2013/06/13 PHP
PHP速成大法
2015/01/30 PHP
PHP实现字符串翻转功能的方法【递归与循环算法】
2017/11/03 PHP
php中钩子(hook)的原理与简单应用demo示例
2019/09/03 PHP
第一个JavaScript入门基础 document.write输出
2010/02/22 Javascript
JQuery中getJSON的使用方法
2010/12/13 Javascript
JavaScript打开word文档的实现代码(c#)
2012/04/16 Javascript
js、css、img等浏览器缓存问题的2种解决方案
2013/10/23 Javascript
Extjs改变树节点的勾选状态点击按钮将复选框去掉
2013/11/14 Javascript
Vue.js学习之计算属性
2017/01/22 Javascript
利用babel将es6语法转es5的简单示例
2017/12/01 Javascript
在Node.js下运用MQTT协议实现即时通讯及离线推送的方法
2019/01/24 Javascript
JavaScript中break、continue和return的用法区别实例分析
2020/03/02 Javascript
2分钟实现一个Vue实时直播系统的示例代码
2020/06/05 Javascript
js 获取扫码枪输入数据的方法
2020/06/10 Javascript
vue实现防抖的实例代码
2021/01/11 Vue.js
详谈在flask中使用jsonify和json.dumps的区别
2018/03/26 Python
python Django中models进行模糊查询的示例
2019/07/18 Python
Flask框架学习笔记之路由和反向路由详解【图文与实例】
2019/08/12 Python
pytorch 自定义数据集加载方法
2019/08/18 Python
python使用if语句实现一个猜拳游戏详解
2019/08/27 Python
Python实现手机号自动判断男女性别(实例解析)
2019/12/22 Python
Python面向对象程序设计之私有变量,私有方法原理与用法分析
2020/03/23 Python
Python tornado上传文件的功能
2020/03/26 Python
python使用scapy模块实现ping扫描的过程详解
2021/01/21 Python
日本小田急百货官网:Odakyu
2018/07/19 全球购物
大学生文员专业个人求职信范文
2014/01/05 职场文书
企业给企业的表扬信
2014/01/13 职场文书
总经理工作职责范文
2014/03/14 职场文书
保护环境倡议书500字
2014/05/19 职场文书
健康状况证明模板
2014/10/23 职场文书
2014年化工厂工作总结
2014/11/25 职场文书
2016年全国爱牙日宣传活动总结
2016/04/05 职场文书
2019XX公司员工考核管理制度!
2019/08/07 职场文书
基于Redis过期事件实现订单超时取消
2021/05/08 Redis