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

发布时间 - 2026-01-11 02:17:51    点击率:

本文介绍了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);
 }

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


# AngularJs4图片剪裁组件  # AngularJs4图片剪裁  # AngularJS中的模块详解  # angular4模块中给标签添加背景图的实现方法  # 就能  # 就可以  # 啦啦  # 有一个  # 自己的  # 的是  # 是一个  # 这是  # 桥接  # 就会  # 让你  # 有个  # 我来  # 你能  # 大神  # 弹出  # 在里面  # 一个叫  # 放着  # 装了 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel怎么连接多个数据库_Laravel多数据库连接配置  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  Laravel怎么使用Blade模板引擎_Laravel模板继承与Component组件复用【手册】  专业商城网站制作公司有哪些,pi商城官网是哪个?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  如何在景安云服务器上绑定域名并配置虚拟主机?  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  香港服务器租用每月最低只需15元?  如何在服务器上配置二级域名建站?  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  浅谈javascript alert和confirm的美化  如何在宝塔面板中创建新站点?  如何快速重置建站主机并恢复默认配置?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  Laravel如何使用Collections进行数据处理?(实用方法示例)  如何正确下载安装西数主机建站助手?  PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)  Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  高防服务器租用指南:配置选择与快速部署攻略  免费网站制作appp,免费制作app哪个平台好?  Python企业级消息系统教程_KafkaRabbitMQ高并发应用  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  制作企业网站建设方案,怎样建设一个公司网站?  晋江文学城电脑版官网 晋江文学城网页版直接进入  如何快速打造个性化非模板自助建站?  Laravel如何实现API版本控制_Laravel API版本化路由设计策略  Firefox Developer Edition开发者版本入口  ,交易猫的商品怎么发布到网站上去?  如何在云虚拟主机上快速搭建个人网站?  Android自定义listview布局实现上拉加载下拉刷新功能  如何为不同团队 ID 动态生成多个非值班状态按钮  如何在云主机快速搭建网站站点?  香港服务器部署网站为何提示未备案?  Laravel如何使用Vite进行前端资源打包?(配置示例)  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  Laravel PHP版本要求一览_Laravel各版本环境要求对照  Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  zabbix利用python脚本发送报警邮件的方法  LinuxShell函数封装方法_脚本复用设计思路【教程】  Android Socket接口实现即时通讯实例代码  如何获取PHP WAP自助建站系统源码?  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  米侠浏览器网页背景异常怎么办 米侠显示修复  微信小程序 scroll-view组件实现列表页实例代码  简单实现Android验证码  Laravel怎么实现验证码(Captcha)功能  再谈Python中的字符串与字符编码(推荐)