詳細AngularJs4的圖片剪裁組件的實例
本文介紹了AngularJs4的圖片剪裁組件,下面我來記錄一下,有需要了解AngularJs4的圖片剪裁組件的朋友可參考。希望此文章對各位有所幫助。
jQuery里有一個強大的圖片剪裁插件,叫cropper.js。這是大神的GitHub地址:https://github.com/fengyuanchen/cropper
首先想在全是ts文件的angular里運用jquery的js代碼插件,這時候需要一個東西,他叫橋接文件。npm是一個強大的庫,已經有前人在里面封裝了cropper以及所有你能想到想不到的插件,你需要做的只是安裝上就好了。需要在webstorm的Terminal里敲npm install cropperJs 這樣在node_modules文件夾里就會出現(xiàn)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); } });
接下來就可以寫代碼啦啦啦啦~~
創(chuàng)建一個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生效自己封裝的樣式。
想要實現(xiàn)點擊一個按鈕,彈出一個框讓你選圖片,需要做的是寫一個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); }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
如何利用@angular/cli V6.0直接開發(fā)PWA應用詳解
這篇文章主要給大家介紹了如何利用@angular/cli V6.0直接開發(fā)PWA應用的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用@angular/cli V6.0具有一定的參考學習價值,需要的朋友可以參考下2018-05-05Angular5升級RxJS到5.5.3報錯:EmptyError: no elements in sequence的解
這篇文章主要給大家介紹了關于Angular5升級RxJS到5.5.3報錯:EmptyError: no elements in sequence的解決方法,文中介紹了兩個解決方法,大家可以選擇使用,需要的朋友可以參考借鑒,下面來一起看看吧。2018-04-04AngularJS中的$parse服務與$eval服務用法實例
這篇文章主要介紹了AngularJS中的$parse服務與$eval服務用法,結合實例形式分析了AngularJS中$parse服務與$eval服務的功能、使用方法與相關注意事項,需要的朋友可以參考下2023-05-05Angularjs的$http異步刪除數(shù)據(jù)詳解及實例
這篇文章主要介紹了Angularjs的$http異步刪除數(shù)據(jù)詳解及實例的相關資料,這里提供實現(xiàn)思路及實現(xiàn)具體的方法,需要的朋友可以參考下2017-07-07關于angular js_$watch監(jiān)控屬性和對象詳解
下面小編就為大家?guī)硪黄P于angular js_$watch監(jiān)控屬性和對象詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04