Vue-电子签名(E-Signature)

本文介绍了一种使用Vue.js实现电子签名的方法,通过Canvas元素收集用户的签名并将其转换为Base64格式保存。该方案支持移动端和PC端,详细展示了如何通过鼠标事件绘制签名。

业务场景

  • 用户在页面使用电子签名进行文件的签收与信息的确认

分析

  • 考虑用户会通过手机或者PC端进行操作,因此需要在事件中考虑手机端部分

思路

  • 通过一个对话框的形式利用Canvas生成图片并通过toDataURL()转换成Base64的形式保存下来提交给后端进行保存

最终效果

实际效果展示
组件效果
组件效果
电子签名

实现

export default {
  name: 'ESignature',
  data() {
    return {
      points: [],
      canvasTxt: null,
      stage_info: [],
      startX: 0,
      startY: 0,
      moveY: 0,
      moveX: 0,
      isDown: false,
      strokeStyle: '#000',
      lineWidth: 2
    }
  },
  mounted() {
    this.initCanvas()
  },
  methods: {
    // 初始化Canvas
    initCanvas() {
      let canvas = this.$refs.canvasF
      // 获取画布的高度
      canvas.height = this.$refs.canvasHW.offsetHeight - 20
      // 获取画布的宽度
      canvas.width = this.$refs.canvasHW.offsetWidth - 20
      // 创建 context 对象
      this.canvasTxt = canvas.getContext('2d')
      this.stage_info = canvas.getBoundingClientRect()
    },
    // 鼠标按下事件 - 准备绘画
    mouseDown(ev) {
      ev = ev || event
      ev.preventDefault()
      if (ev) {
        let obj = {
          x: ev.offsetX,
          y: ev.offsetY
        }
        this.startX = obj.x
        this.startY = obj.y
        this.canvasTxt.beginPath()
        this.canvasTxt.moveTo(this.startX, this.startY)
        this.canvasTxt.lineTo(obj.x, obj.y)
        this.canvasTxt.stroke()
        this.canvasTxt.closePath()
        this.points.push(obj)
        this.isDown = true
      }
    },
    // 鼠标移动事件 - 开始绘画
    mouseMove(ev) {
      ev = ev || event
      ev.preventDefault()
      if (this.isDown) {
        let obj = {
          x: ev.offsetX,
          y: ev.offsetY
        }
        this.moveY = obj.y
        this.moveX = obj.x
        this.canvasTxt.strokeStyle = this.strokeStyle
        this.canvasTxt.lineWidth = this.lineWidth
        this.canvasTxt.beginPath()
        this.canvasTxt.moveTo(this.startX, this.startY)
        this.canvasTxt.lineTo(obj.x, obj.y)
        this.canvasTxt.stroke()
        this.canvasTxt.closePath()
        this.startY = obj.y
        this.startX = obj.x
        this.points.push(obj)
      }
    },
    // 松开鼠标事件 - 停止绘画
    mouseUp(ev) {
      ev = ev || event
      ev.preventDefault()
      if (ev) {
        let obj = {
          x: ev.offsetX,
          y: ev.offsetY
        }
        this.canvasTxt.beginPath()
        this.canvasTxt.moveTo(this.startX, this.startY)
        this.canvasTxt.lineTo(obj.x, obj.y)
        this.canvasTxt.stroke()
        this.canvasTxt.closePath()
        this.points.push(obj)
        this.points.push({ x: -1, y: -1 })
        this.isDown = false
      }
    },
    // 返回
    handleGoBack() {
      this.handleOverwrite()
      this.$emit('on-back')
    },
    // 重写
    handleOverwrite() {
      this.canvasTxt.clearRect(0, 0, this.$refs.canvasF.width, this.$refs.canvasF.height)
      this.points = []
    },
  }
}
详情请看:Vue-电子签名(E-Signature)
### Vue.js 中用于电子签名的组件或插件 对于希望在 Vue.js 项目中集成电子签名功能的应用程序来说,存在多种解决方案。一种流行的选择是 `vue-signature-pad` 插件[^1]。 #### 安装 vue-signature-pad 为了使用此库,在命令行工具中执行如下 npm 命令来安装依赖项: ```bash npm install vue-signature-pad --save ``` #### 导入并注册组件 接着可以在单文件组件内通过 ES6 的 import 语句加载它,并将其作为局部组件进行声明: ```javascript import SignaturePad from 'vue-signature-pad' const { signaturePad } = SignaturePad; export default { components: { signaturePad, }, } ``` #### HTML 模板部分 下面展示如何将 `<signature-pad>` 标签嵌入到页面布局里: ```html <template> <div id="app"> <signature-pad ref="signaturePad" width="500px" height="300px"></signature-pad> <!-- 渲染其他 UI 元素 --> </div> </template> ``` #### 方法与事件监听 还可以定义一些辅助函数用来获取绘制的数据以及清除画布上的内容;同时也可以绑定相应的事件处理器以便响应用户的交互操作: ```javascript methods:{ clearCanvas(){ this.$refs.signaturePad.clearSignature(); }, getSignatureData(){ let dataURL = this.$refs.signaturePad.saveSignature(); console.log(dataURL); } }, mounted() { this.$refs.signaturePad.onBeginEvent = () => { console.log('开始签名'); }; this.$refs.signaturePad.onEndEvent = () => { console.log('结束签名'); }; } ``` 以上就是关于怎样利用 `vue-signature-pad` 实现基本的电子签名特性的介绍。当然除了上述提到的功能外,该库还提供了更多高级选项可供开发者探索尝试。
评论 14
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值