前端电子签名在vue3中使用

主要使用插件vue-esign,通过上方调整颜色背景线条粗细

以下是使用步骤

1.npm install vue-esign --save

2.在main.js中引入

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

3.页面中使用

<template>
  线条颜色:<input type="color" v-model="lineColor">
  背景颜色:<input type="color" v-model="bgColor">
  <vue-esign ref="esign" :width="800" :height="300" :isCrop="isCrop" :lineWidth="lineWidth" :lineColor="lineColor"
    :bgColor.sync="bgColor" />
  <button @click="handleReset">清空画板</button>
  <button @click="handleGenerate">生成图片</button>
  <img :src="resultImg"/>
  <a :href="href" download="aaa.png" ref="downloadFile" style="height:0px;"></a>
</template>

<script lang="ts" setup>
import { ref,nextTick } from 'vue'
const href = ref()//a链接接口地址
const downloadFile = ref()//aDom元素
const lineWidth = ref(6)//线条宽度
const lineColor = ref('')//线条颜色
const bgColor = ref('')//背景颜色
const resultImg = ref('')//拿到的图片的base64
const isCrop = ref(false)//是否可裁剪
const esign = ref()//组件dom
// 清空组件
function handleReset() {
  esign.value.reset()
  resultImg.value = ''
}
//生成图片,并下载图片
function handleGenerate() {
  esign.value.generate().then((res: any) => {
    resultImg.value = res
    // 下载图片
    href.value = res
    nextTick(() => {
      downloadFile.value.click()
    })
  }).catch(err => {
    alert(err) // 画布没有签字时会执行这里 'Not Signned'
  })
}


</script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值