Use vue to implement handwritten signature function

Use vue to implement handwritten signature function

Personal implementation screenshots:

Install:

npm install vue-esign --save

use:

1. Import in main.js

import vueEsign from 'vue-esign'
Vue.use(vueEsign)

2. Quote in the page

<vue-esign ref="esign" :width="800" :height="300" :isCrop="isCrop" :lineWidth="lineWidth" :lineColor="lineColor" :bgColor.sync="bgColor" />
 
<button @click="handleReset">Clear the drawing board</button>
 
<button @click="handleGenerate">Generate image</button>

3. Description

property type default value illustrate
width Number 800 Canvas width, that is, the width of the exported image
height Number 300 Canvas height, i.e. the height of the exported image
lineWidth 4 Number Brush Thickness
lineColor String #000000 Brush Color
bgColor String null The canvas background color. When it is empty, the canvas background is transparent.
Supports multiple formats '#ccc', '#E5A1A1', 'rgb(229, 161, 161)', 'rgba(0,0,0,.6)', 'red'
isCrop Boolean false Whether to crop, based on the canvas setting size, cut off the blank area around it

Long awaited, here is the original code:

data () {
  return {
    lineWidth: 6,
    lineColor: '#000000',
    bgColor: '',
    resultImg: '',
    isCrop: false
  }
},
methods: {
  handleReset () {
    this.$refs['esign'].reset() //Clear the canvas},
  handleGenerate() {
    this.$refs['esign'].generate().then(res => {
      this.resultImg = res // Get the base64 image generated by the signature}).catch(err => { // No signature, call this.$message({
        message: err + ' Unsigned! ',
        type: 'warning'
      })
      alert(err) // This will be executed when the canvas is not signed'Not Signned'
    })
  }
}

Appendix : How to convert base64 into pictures:

// Convert base64 to image base64ImgtoFile(dataurl, filename = 'file') {
 
const arr = dataurl.split(',')
 
const mime = arr[0].match(/:(.*?);/)[1]
 
const suffix = mime.split('/')[1]
 
const bstr = atob(arr[1])
 
let n = bstr.length
 
const u8arr = new Uint8Array(n)
 
while (n--) {
 
u8arr[n] = bstr.charCodeAt(n)
 
}
 
return new File([u8arr], `${filename}.${suffix}`, {
 
type: mime
 
})
 
},

This is the end of this article about using vue to implement handwritten signature function. For more relevant vue implementation of handwritten signature content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Vue uses canvas to implement handwritten electronic signature
  • Vue+element adds signature effect (available on mobile devices)
  • vue vue-esign signature board demo

<<:  Setting up VMware vSphere in VMware Workstation (Graphic Tutorial)

>>:  VMware ESXi 6.0 and deployment of virtual machine installation tutorial (picture and text)

Recommend

Solution to the garbled code problem in MySQL 5.x

MySQL is a commonly used open source database sof...

Detailed explanation of the use of Linux time command

1. Command Introduction time is used to count the...

Summary of 4 methods of div+css layout to achieve 2-end alignment of css

The div+css layout to achieve 2-end alignment is ...

Example of creating table statements for user Scott in MySQL version of Oracle

Overview: Oracle scott user has four tables, whic...

What is COLLATE in MYSQL?

Preface Execute the show create table <tablena...

Steps to enable TLS in Docker for secure configuration

Preface I had previously enabled Docker's 237...

How to deploy hbase using docker

Standalone hbase, let’s talk about it first. Inst...

js to create a carousel effect

I think the carousel is a relatively important po...

Analysis and description of network configuration files under Ubuntu system

I encountered a strange network problem today. I ...

MySQL 8.0 New Features - Introduction to the Use of Management Port

Table of contents Preface Connection Management A...

The most complete package.json analysis

Table of contents 1. Overview 2. Name field 3. Ve...

Differences between ES6 inheritance and ES5 inheritance in js

Table of contents Inheritance ES5 prototype inher...