IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 图片裁剪cropperjs的使用 -> 正文阅读

[JavaScript知识库]图片裁剪cropperjs的使用

文档地址:https://fengyuanchen.github.io/cropperjs/

使用方式:

.1 下载包

yarn add cropperjs

.2 导入包

importCropperfrom"cropperjs"

import"cropperjs/dist/cropper.css"

.3 自定义裁剪比例

 const sizeList = [
? {
? ? name: "1:1",
? ? size: 1 / 1,
? },
? {
? ? name: "16:9",
? ? size: 16 / 9,
? },
? {
? ? name: "4:3",
? ? size: 4 / 3,
? },
? {
? ? name: "2:3",
? ? size: 2 / 3,
? },
? {
? ? name: "自由尺寸",
? ? size: NaN,
? },
]

.4 准备 state 数据


constructor(props) {
? ? super(props)
? ? this.imgRef = React.createRef()
? ? this.state = {
? ? ? buttonLoading: false,
? ? ? currenIndex: 0,
? ? }
? }

.5 准备 html 结构

 render() {
? ? const { meCropShow, imgUrl } = this.props
? ? const { buttonLoading, currenIndex } = this.state
? ? return (
? ? ? <Modal
? ? ? ? className="meCropModal_view"
? ? ? ? width="50%"
? ? ? ? title="图片裁剪"
? ? ? ? maskClosable={false}
? ? ? ? closable={false}
? ? ? ? visible={meCropShow}
? ? ? ? onCancel={this.cancelFn}
? ? ? ? footer={[
? ? ? ? ? <Button onClick={this.cancelFn}>取消</Button>,
? ? ? ? ? <Button onClick={this.okFn} loading={buttonLoading}>
? ? ? ? ? ? 确认
? ? ? ? ? </Button>,
? ? ? ? ]}
? ? ? >
? ? ? ? <div className="meCropModal_content">
? ? ? ? ? <img src={imgUrl} ref={this.imgRef} className="meCropModal_img" />
? ? ? ? </div>

? ? ? ? <Space className="cropSize_view" size="large">
? ? ? ? ? {sizeList.map((item, index) => {
? ? ? ? ? ? return (
? ? ? ? ? ? ? <Tag
? ? ? ? ? ? ? ? color={index === currenIndex ? "blue" : ""}
? ? ? ? ? ? ? ? key={item.name}
? ? ? ? ? ? ? ? onClick={this.setSize.bind(this, item.size, index)}
? ? ? ? ? ? ? >
? ? ? ? ? ? ? ? {item.name}
? ? ? ? ? ? ? </Tag>
? ? ? ? ? ? )
? ? ? ? ? })}
? ? ? ? </Space>
? ? ? </Modal>
? ? )
? }

.6 准备 css

.cropper-modal {
? background-color: rgba(0, 0, 0, 0.2);
}
//注意 一定要为裁剪框的父元素设置大小
.meCropModal_content {
? width: 100%;
? height: 500px;
}
.meCropModal_img {
? width: 100%;
}

.7 初始化裁剪框

this.newCropper(sizeList[0].size)

newCropper = (aspectRatio) => {
? ? let myCropper = new Cropper(this.imgRef.current, {
? ? ? viewMode: 1,
? ? ? preview: ".before",
? ? ? zoomOnWheel: false,
? ? ? autoCropArea: 0.6,
? ? ? dragMode: "none",
? ? ? background: false,
? ? ? initialAspectRatio: 1,
? ? ? outputType: "png",
? ? ? ready() {
? ? ? ? myCropper.setAspectRatio(aspectRatio)
? ? ? },
? ? })

? ? this.setState({
? ? ? myCropper,
? ? })
}

.8 若要改变裁剪比例 则执行以下代码

/** @params 
val:代表要裁剪的比例
index:当前比例的index值 为了指定样式
 */
setSize = (val, index) => {
? ? this.setState({
? ? ? currenIndex: index,
? ? })
? ? /** 这一块坑爹的很 文档上有reset方法和clear方法 试过了都不行 然后人家的示范又能正常切换比例 只好打开sourcemap看看有没有源代码 碰碰运气 结果还真找到了 一看是有这么一个销毁的方法 文档里写的也不太详细 看半天没看到这么一个方法 坑爹的 加上这一句后 立马就好了 */
? ? this.state.myCropper.destroy() //先销毁裁剪框 在重新设置比例
? ? this.newCropper(val)
? }

.9 确认裁剪的方法

okFn = async () => {
? ? this.setState({
? ? ? buttonLoading: true,
? ? })
? ? let url = this.state.myCropper
? ? ? .getCroppedCanvas({
? ? ? ? imageSmoothingQuality: "high",
? ? ? ? outputType: "png",//这个好像并没有用 可写可不写
? ? ? ? fillColor: "#fff", //设置背景色 意思就是在裁剪透明png图片的时候 默认裁剪出来是黑色背景 此处修改为白色背景
? ? ? })
? ? ? .toDataURL("image/jpeg")

?? ?//此方法是将图片的base64转换为file对象
? ? let files = this.base64toFile(url)

? ? if (files) {
? ? ? var file = new FormData()
? ? ? file.append("file", files)
? ? ? file.append("token", this.state.qiToken)
? ? ? file.append("key", y.randomCount())

? ? ? const res = await instImg({
? ? ? ? method: "post",
? ? ? ? url: "http://upload.qiniu.com",
? ? ? ? data: file,
? ? ? })

? ? ? if (res.status === 200) {
? ? ? ? let key = res.data.key
?? ?//此方法是自定义的子传父的通讯方法 触发后在父组件进行要执行的操作
? ? ? ? this.props.cancleFn({ type: 1, key: key })
? ? ? } else {
? ? ? ? message.info("上传异常,请稍后重新尝试")
? ? ? }

? ? ? this.setState({
? ? ? ? buttonLoading: false,
? ? ? })
? ? }
? }

? /*base64转换为file对象 ?*/
? base64toFile = (dataurl, filename) => {
? ? //将base64转换为文件
? ? var arr = dataurl.split(","),
? ? ? mime = arr[0].match(/:(.*?);/)[1],
? ? ? bstr = atob(arr[1]),
? ? ? n = bstr.length,
? ? ? u8arr = new Uint8Array(n)
? ? while (n--) {
? ? ? u8arr[n] = bstr.charCodeAt(n)
? ? }
? ? return new File([u8arr], filename, { type: mime })
? }

? cancelFn = () => {
? ? this.props.cancleFn({ type: 2 })
? }

.10 在需要的地方导入封装好的裁剪框

import MeCrop from "component/meCrop/meCrop"

.11 父组件的 html 与 state

? state = {
? ? meCropShow: false,
? ? imgUrl: null,
? }

? {meCropShow && (
? ? ? ? ? <MeCrop
? ? ? ? ? ? meCropShow={meCropShow}
? ? ? ? ? ? cancleFn={this.cancleFn}
? ? ? ? ? ? imgUrl={imgUrl}
? ? ? ? ? ></MeCrop>
? ?)}

.12 父组件的通讯回调

? cancleFn = (parmas) => {
? ? const { type } = parmas

? ? if (type == 1) {
? ? ? const { key } = parmas
? ? ? this.setState({
? ? ? ? formData: {
? ? ? ? ? ...this.state.formData,
? ? ? ? ? cover: key,
? ? ? ? },
? ? ? })
? ? }
? ? this.setState({
? ? ? meCropShow: false,
? ? })
? }

.13 效果图

.14 over了

其实我长得就跟上面那个图一样帅!

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-15 22:23:40  更:2022-03-15 22:26:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:06:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码