Vue-cropperjs图片裁剪方案,如何改写为长尾词?

2026-03-31 16:151阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1010个文字,预计阅读时间需要5分钟。

Vue-cropperjs图片裁剪方案,如何改写为长尾词?

目录- 引用- 图片裁剪流程- 使用vue-cropperjs- 代码实现- 实现效果- 使用v-viewer- 代码实现- 实现效果- 最后- 引用- 完成了一个图片裁剪和预览的功能,支持前端图片裁剪,并可通过v-viewer进行图片预览。

目录
  • 引言
  • 图片裁剪
    • 图片裁剪的流程
    • vue-cropperjs的使用
      • 代码实现
      • 实现效果
    • v-viewer的使用
      • 代码实现
      • 实现效果
  • 最后

    引言

    做了个图片的裁剪的功能和预览的功能,前端图片的裁剪方案,大多数都是用cropperjs进行封装,npm上有vue-cropperjs可以直接用起来,viewerjs是用来实现图片的预览,这里直接使用了v-viewer来实现。

    可以点击现在地址体验喔

    git仓库地址 以及在线demo地址

    图片裁剪

    图片裁剪的流程

    • 首先使用el-upload组件,渲染已经存在或者裁剪过的图片
    • 点击文件上传,选中需要裁剪的图片
    • 弹出一个弹框,在弹框中使用vue-cropperjs实现图片裁剪
    • 裁剪完成后,通过回调函数,将处理后的图片文件(Blob格式)上传到服务器或者本地预览出来
    • 裁剪完成的图片列表,通过v-viewer实现点击全屏预览(辅助作用)

    vue-cropperjs的使用

    代码实现

    • 首先在组件注册VueCropper组件
    • 直接可以通过vue-cropper标签使用组件
    • 设置this.$refs.cropper.setAspectRatio(1)之后,图片只能按照一定的比例裁剪,想要随意裁剪可以不设置
    • 通过this.$refs.cropper.relativeZoom、this.onRotateDegreeChange、this.$refs.cropper.move、this.$refs.cropper.scaleX 等API,可以对图片进行平移、缩放、翻转、旋转等操作
    • 通过this.$refs.cropper.getCroppedCanvas().toBlob()获取到处理后图片的Blob格式文件
    • Blob格式文件处理成File格式后,上传到服务器

    // 引入组件并注册 import "cropperjs/dist/cropper.css"; import VueCropper from "vue-cropperjs"; // 直接使用组件 <vue-cropper overflow-hidden ref="cropper" :src="src" preview=".preview" :minContainerHeight="500" background :ready="onReady" /> // 图片可以在onReady方法中设置裁剪的宽高比例 this.$refs.cropper.setAspectRatio(this.aspectRatioValue); // 缩放图片 this.$refs.cropper.relativeZoom(percent); // 图片旋转角度 this.onRotateDegreeChange(this.rotateDegree); // 图片平移 this.$refs.cropper.move(offsetX, offsetY); // 图片翻转 this.$refs.cropper.scaleX(scale); this.$refs.cropper.scaleY(scale); // 重置 this.$refs.cropper.reset(); // 获取修改后的图片的数据 this.$refs.cropper .getCroppedCanvas({ // 限制画布大小,限制生成的图片体积 maxWidth: 2056, maxHeight: 2056, }) .toBlob( (blob) => { // 调用确定的回调函数,将blob上传到服务器或者本地预览 this.$emit("confirm", blob); }, // 如果旋转角度不为直角,则图片一定会出现空白区域,空白区域默认透明,使用 png 格式 //this.rotateDegree % 90 === 0 ? this.file.type : 'image/png', this.file.type, // 质量 this.quality ); // 将文件上传到服务器 function onCropperConfirm(blob) { let file = new File([blob], filename, { type: blob.type,}); const formData = new FormData(); formData.append("file", file); // ... axios.post("/upload", formData).then((res) => { // ... }) }

    实现效果

    Vue-cropperjs图片裁剪方案,如何改写为长尾词?

    v-viewer的使用

    代码实现

    v-viewer主要的实现图片的全屏预览,基于viewerjs封装

    • 首先在main.js中引入css和注册v-viewer插件
    • 在页面中可以直接通过this.$viewerApi 调用,传入图片路径的数组和对应的索引,实现全屏预览图片

    // 首先在main.js中引入组件 import "viewerjs/dist/viewer.css"; import VueViewer from "v-viewer"; Vue.use(VueViewer); // 组件中使用 this.$viewerApi({ options: { toolbar: true, initialViewIndex: 1, }, images: [ "placem.at/people?random=1&txt=0&w=500&h=500", "placem.at/people?random=1&txt=0&w=1000&h=500" ], });

    实现效果

    参考资料

    www.npmjs.com/package/v-v…

    www.npmjs.com/package/vue…

    推荐js前端实现wordexcelpdfpptmp4图片文本等文件预览

    最后

    图片剪裁使用插件实现的话,只能说CV工程师不要太爽,要了解原理的话,还是需要花费很多时间研究的;更多关于前端vue-cropperjs图片裁剪的资料请关注易盾网络其它相关文章!

    本文共计1010个文字,预计阅读时间需要5分钟。

    Vue-cropperjs图片裁剪方案,如何改写为长尾词?

    目录- 引用- 图片裁剪流程- 使用vue-cropperjs- 代码实现- 实现效果- 使用v-viewer- 代码实现- 实现效果- 最后- 引用- 完成了一个图片裁剪和预览的功能,支持前端图片裁剪,并可通过v-viewer进行图片预览。

    目录
    • 引言
    • 图片裁剪
      • 图片裁剪的流程
      • vue-cropperjs的使用
        • 代码实现
        • 实现效果
      • v-viewer的使用
        • 代码实现
        • 实现效果
    • 最后

      引言

      做了个图片的裁剪的功能和预览的功能,前端图片的裁剪方案,大多数都是用cropperjs进行封装,npm上有vue-cropperjs可以直接用起来,viewerjs是用来实现图片的预览,这里直接使用了v-viewer来实现。

      可以点击现在地址体验喔

      git仓库地址 以及在线demo地址

      图片裁剪

      图片裁剪的流程

      • 首先使用el-upload组件,渲染已经存在或者裁剪过的图片
      • 点击文件上传,选中需要裁剪的图片
      • 弹出一个弹框,在弹框中使用vue-cropperjs实现图片裁剪
      • 裁剪完成后,通过回调函数,将处理后的图片文件(Blob格式)上传到服务器或者本地预览出来
      • 裁剪完成的图片列表,通过v-viewer实现点击全屏预览(辅助作用)

      vue-cropperjs的使用

      代码实现

      • 首先在组件注册VueCropper组件
      • 直接可以通过vue-cropper标签使用组件
      • 设置this.$refs.cropper.setAspectRatio(1)之后,图片只能按照一定的比例裁剪,想要随意裁剪可以不设置
      • 通过this.$refs.cropper.relativeZoom、this.onRotateDegreeChange、this.$refs.cropper.move、this.$refs.cropper.scaleX 等API,可以对图片进行平移、缩放、翻转、旋转等操作
      • 通过this.$refs.cropper.getCroppedCanvas().toBlob()获取到处理后图片的Blob格式文件
      • Blob格式文件处理成File格式后,上传到服务器

      // 引入组件并注册 import "cropperjs/dist/cropper.css"; import VueCropper from "vue-cropperjs"; // 直接使用组件 <vue-cropper overflow-hidden ref="cropper" :src="src" preview=".preview" :minContainerHeight="500" background :ready="onReady" /> // 图片可以在onReady方法中设置裁剪的宽高比例 this.$refs.cropper.setAspectRatio(this.aspectRatioValue); // 缩放图片 this.$refs.cropper.relativeZoom(percent); // 图片旋转角度 this.onRotateDegreeChange(this.rotateDegree); // 图片平移 this.$refs.cropper.move(offsetX, offsetY); // 图片翻转 this.$refs.cropper.scaleX(scale); this.$refs.cropper.scaleY(scale); // 重置 this.$refs.cropper.reset(); // 获取修改后的图片的数据 this.$refs.cropper .getCroppedCanvas({ // 限制画布大小,限制生成的图片体积 maxWidth: 2056, maxHeight: 2056, }) .toBlob( (blob) => { // 调用确定的回调函数,将blob上传到服务器或者本地预览 this.$emit("confirm", blob); }, // 如果旋转角度不为直角,则图片一定会出现空白区域,空白区域默认透明,使用 png 格式 //this.rotateDegree % 90 === 0 ? this.file.type : 'image/png', this.file.type, // 质量 this.quality ); // 将文件上传到服务器 function onCropperConfirm(blob) { let file = new File([blob], filename, { type: blob.type,}); const formData = new FormData(); formData.append("file", file); // ... axios.post("/upload", formData).then((res) => { // ... }) }

      实现效果

      Vue-cropperjs图片裁剪方案,如何改写为长尾词?

      v-viewer的使用

      代码实现

      v-viewer主要的实现图片的全屏预览,基于viewerjs封装

      • 首先在main.js中引入css和注册v-viewer插件
      • 在页面中可以直接通过this.$viewerApi 调用,传入图片路径的数组和对应的索引,实现全屏预览图片

      // 首先在main.js中引入组件 import "viewerjs/dist/viewer.css"; import VueViewer from "v-viewer"; Vue.use(VueViewer); // 组件中使用 this.$viewerApi({ options: { toolbar: true, initialViewIndex: 1, }, images: [ "placem.at/people?random=1&txt=0&w=500&h=500", "placem.at/people?random=1&txt=0&w=1000&h=500" ], });

      实现效果

      参考资料

      www.npmjs.com/package/v-v…

      www.npmjs.com/package/vue…

      推荐js前端实现wordexcelpdfpptmp4图片文本等文件预览

      最后

      图片剪裁使用插件实现的话,只能说CV工程师不要太爽,要了解原理的话,还是需要花费很多时间研究的;更多关于前端vue-cropperjs图片裁剪的资料请关注易盾网络其它相关文章!