使用Vue.js实现图像裁剪功能


本文摘自PHP中文网,作者青灯夜游,侵删。

你是否写了一个需要接受用户上传图片的 Web 应用,后来才意识到用户总是提供各种形状和大小的图像来破坏你的网站主题?在网络上处理图像很容易成为一种痛苦 ―― 当然,除非你使用了正确的工具。

在本教程中,我们将探讨如何在浏览器中使用 JavaScript 库来操作图片,为服务器上的存储做准备,并在 Web 程序中使用。我们将使用 Vue.js 而不是原生 JavaScript来完成此操作。

要了本文想要完成的任务,请查看上面的图片。左侧是原始图像,右侧是新图像预览。我们可以移动裁剪框并调整其大小,预览图像也会随之改变。用户可以根据需要下载预览图像。

我们将使用名为 Cropper.js 的库完成繁重的工作。

使用图像裁剪依赖项创建一个新的Vue.js项目

第一步是创建一个新项目并安装必要的依赖项。假设你已安装并配置了Vue CLI。

在命令行下执行以下命令:

1

vue create cropper-project

出现提示时,选择默认选项。这将是一个简单的项目,所以不必要担心路由和其它一些东西。

导航到新项目并执行以下操作:

1

npm install cropperjs --save

上面的命令会将 Cropper.js 安装到我们的项目中。可以很容易地使用CDN,但因为我们使用的是利用 webpack 的框架,所以 npm 路由最有意义。

虽然安装了我们的依赖项,但还有一件事需要去做。因为用的是 npm,所以不包含CSS信息 ―― 只包含 JavaScript 信息。我们需要在本地或通过 CDN 包含 CSS信 息。本文使用CDN。

打开项目的 public/index.html 并包含以下 HTML 标记:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<meta http-equiv="X-UA-Compatible" content="IE=edge">

<meta name="viewport" content="width=device-width,initial-scale=1.0">

<link rel="icon" href="<%= BASE_URL %>favicon.ico">

<title>image-cropping</title>

<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/cropperjs/1.5.1/cropper.min.css">

</head>

<body>

    <noscript>

        <strong>

        We're sorry but image-cropping doesn't work properly without JavaScript enabled.

        Please enable it to continue.

        </strong>

    </noscript>

    <div id="app"></div>

    <!-- built files will be auto injected -->

</body>

</html>

请注意,在 <head> 标记中,我们包含了 cropper.min.css 文件。同样,只要你得到这个文件,如何获得CSS信息并不重要。如果没有 CSS 信息,我们的图像就不会有花哨的裁剪框。

在Vue.js项目中使用JavaScript裁剪图像

现在项目应该几乎已配置好并可以在网络上裁剪图像。为了保持我们的项目整洁,我们将创建一个新的Vue.js组件来处理我们所有的图像处理。

在项目中创建 src/components/ImageCropper.vue 文件,并包含以下样板代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

<template>

    <div>

        <div class="img-container">

            <img ref="image" :src="src" crossorigin>

        </div>

        <img :src="destination" class="img-preview">

    </div>

</template>

 

<script>

    import Cropper from "cropperjs";

    export default {

        name: "ImageCropper",

        data() {

            return {

                cropper: {},

                destination: {},

                image: {}

            }

        },

        props: {

            src: String

        },

        mounted() { }

    }

</script>

 

<style scoped>

    .img-container {

        width: 640px;

        height: 480px;

        float: left;

    }

    .img-preview {

        width: 200px;

        height: 200px;

        float: left;

        margin-left: 10px;

    }

</style>

对于这个例子,<style> 标签的信息并不重要,它只是清理了页面,并没有从库中获得任何实际效果。

阅读剩余部分

相关阅读 >>

vue框架和react框架的区别是什么

vue.js有哪些ui框架?

什么叫vue.js

vuex中映射的完整指南

angularjs和vue.js有什么差异?简单对比

vue.js中如何获取url的值

分析一下vue.use的源码

vue.js如何设置时间格式

vue.js为什么要用谷歌浏览器

vue.js支持ie8吗

更多相关阅读请进入《vue.js》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...