详细AngularJs4的图片剪裁组件的实例


Posted in Javascript onJuly 12, 2017

本文介绍了AngularJs4的图片剪裁组件,下面我来记录一下,有需要了解AngularJs4的图片剪裁组件的朋友可参考。希望此文章对各位有所帮助。

jQuery里有一个强大的图片剪裁插件,叫cropper.js。这是大神的GitHub地址:https://github.com/fengyuanchen/cropper

首先想在全是ts文件的angular里运用jquery的js代码插件,这时候需要一个东西,他叫桥接文件。npm是一个强大的库,已经有前人在里面封装了cropper以及所有你能想到想不到的插件,你需要做的只是安装上就好了。需要在webstorm的Terminal里敲npm install cropperJs 这样在node_modules文件夹里就会出现cropperjs的文件。有一个@types的文件夹,里面放着你需要用到相对应js插件的ts桥接文件。在Terminal里敲npm install @types/cropperjs

忘了说 在@types下有一个叫index.d.ts的文件,里面有示例:https://github.com/DefinitelyTyped/DefinitelyTyped,在types下搜cropper,有个文件cropperjs-tests.ts,就能看到一个例子,长这样:

import * as Cropper from 'cropperjs';

var image = <HTMLImageElement>document.getElementById('image');
var cropper = new Cropper(image, {
 aspectRatio: 16 / 9,
 crop: function(e) {
  console.log(e.detail.x);
  console.log(e.detail.y);
  console.log(e.detail.width);
  console.log(e.detail.height);
  console.log(e.detail.rotate);
  console.log(e.detail.scaleX);
  console.log(e.detail.scaleY);
 }
});

接下来就可以写代码啦啦啦啦~~

创建一个component

import {Component, Input, AfterViewInit, ViewEncapsulation} from '@angular/core';
import * as Cropper from 'cropperjs';

@Component({
 selector: 'cropper',
 templateUrl: './cropper.component.html',
 styleUrls: ['./cropper.component.less'],
 encapsulation: ViewEncapsulation.None
})

import * as Cropper from 'cropperjs';这个是引用cropper的方式。

encapsulation: ViewEncapsulation.None 因为angular会封装自己的样式,导致自己在less文件里写的样式不生效,这句的意义在于,不让angular生效自己封装的样式。

想要实现点击一个按钮,弹出一个框让你选图片,需要做的是写一个change事件,获取到选中图片的路径,然后运用cropper里的替换路径的replace方法,就能完成换图片显示了。

<input type="file" accept="image/jpeg" (change)="getImgUrl($event)">
getImgUrl($event) {
  this.cropper.replace(window.URL.createObjectURL($event.path[0].files[0])) ;
  console.log($event);
 }

$event 是整个事件对象。

接下来就可以添加自己需要的功能了,比如说向右旋转90度。

<button (click)="rotateRight()">rotate</button>
rotateRight() {
  console.log(this.cropper.getData());
  this.cropper.rotate(90);
 }

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

Javascript 相关文章推荐
jQuery 源代码显示控件 (Ajax加载方式).
May 18 Javascript
JavaScript中判断对象类型的几种方法总结
Nov 11 Javascript
JS获取几种URL地址的方法小结
Feb 26 Javascript
jquery实现顶部向右伸缩的导航区域代码
Sep 02 Javascript
JavaScript函数学习总结以及相关的编程习惯指南
Nov 16 Javascript
jQuery中使用animate自定义动画的方法
May 29 Javascript
基于Bootstrap+jQuery.validate实现表单验证
May 30 Javascript
js实现的在线调色板功能完整实例
Dec 21 Javascript
ES6字符串模板,剩余参数,默认参数功能与用法示例
Apr 06 Javascript
用js实现before和after伪类的样式修改的示例代码
Sep 07 Javascript
使用原生js+canvas实现模拟心电图的实例
Sep 20 Javascript
浅谈vue-cli 3.0.x 初体验
Apr 11 Javascript
JS中使用gulp实现压缩文件及浏览器热加载功能
Jul 12 #Javascript
Vue中的数据监听和数据交互案例解析
Jul 12 #Javascript
js 监控iframe URL的变化实例代码
Jul 12 #Javascript
jQuery 循环遍历改变a标签的href(实例讲解)
Jul 12 #jQuery
浅谈原生JS中的延迟脚本和异步脚本
Jul 12 #Javascript
基于zepto.js实现手机相册功能
Jul 11 #Javascript
React-Native实现ListView组件之上拉刷新实例(iOS和Android通用)
Jul 11 #Javascript
You might like
一步一步学习PHP(4) php 函数 补充2
2010/02/15 PHP
php上的memcache和memcached两个pecl库
2010/03/29 PHP
浅析php数据类型转换
2014/01/09 PHP
PHP 使用redis简单示例分享
2015/03/05 PHP
Smarty分页实现方法完整实例
2016/05/11 PHP
php中实现字符串翻转的方法
2017/02/22 PHP
php显示页码分页类的封装
2017/06/08 PHP
javascript编程起步(第一课)
2007/01/10 Javascript
浅析Node在构建超媒体API中的作用
2014/07/30 Javascript
Javascript 读取操作Sql中的Xml字段
2014/10/09 Javascript
jQuery中before()方法用法实例
2014/12/25 Javascript
javascript实现随时变化着的背景颜色
2015/04/02 Javascript
谈一谈javascript闭包
2016/01/28 Javascript
深入剖析JavaScript面向对象编程
2016/07/12 Javascript
windows 下安装nodejs 环境变量设置
2017/02/02 NodeJs
关于Webpack dev server热加载失败的解决方法
2018/02/22 Javascript
微信小程序实现点击导航标签滚动定位到对应位置
2020/11/19 Javascript
[03:49]DOTA2英雄基础教程 光之守卫
2014/01/14 DOTA
Python全局变量用法实例分析
2016/07/19 Python
python脚本生成caffe train_list.txt的方法
2018/04/27 Python
利用python如何在前程无忧高效投递简历
2019/05/07 Python
Python 窗体(tkinter)按钮 位置实例
2019/06/13 Python
Python登录系统界面实现详解
2019/06/25 Python
python Pillow图像处理方法汇总
2019/10/16 Python
Pyinstaller加密打包应用的示例代码
2020/06/11 Python
10张动图学会python循环与递归问题
2021/02/06 Python
Auchan Direct波兰:欧尚在线杂货店
2016/10/19 全球购物
西班牙英格列斯百货英国官网:El Corte Inglés英国
2017/10/30 全球购物
澳大利亚头发和美容产品购物网站:OZ Hair & Beauty
2020/03/27 全球购物
研修第一天随笔感言
2014/02/15 职场文书
大学生实习鉴定评语
2014/04/25 职场文书
关于感恩的演讲稿800字
2014/08/26 职场文书
2015年团支部工作总结
2015/04/03 职场文书
生活委员竞选稿
2015/11/21 职场文书
python实现网络五子棋
2021/04/11 Python
Django给表单添加honeypot验证增加安全性
2021/05/06 Python