广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue vue-esign签字板的demo
  • 170
分享到

vue vue-esign签字板的demo

2024-04-02 19:04:59 170人浏览 薄情痞子
摘要

目录Vue vue-esign签字板demo安装在main.js中全局引用vue移动端电子签名demovue vue-esign签字板demo 使用vue-esign让用户能够在手动

vue vue-esign签字板demo

使用vue-esign让用户能够在手动签字并返回为base64或者file格式的文件流

安装

npm install vue-esign --save

在main.js中全局引用

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

Demo 

<template>
  <div class="esigns">
    <vue-esign
      ref="esign"
      style="
        width: 100%;
        height: 400px
      "
      :isCrop="isCrop"
      :lineWidth="lineWidth"
      :lineColor="lineColor"
      :bGColor.sync="bgColor"
    />
    <div class="btn">
      <van-button type="primary" @click="handleReset">重置</van-button>
      <van-button type="info" @click="handleGenerate">确定</van-button>
    </div>
  </div>
</template>
<script>
export default {
  name: "Esign",
  data() {
    return {
      lineWidth: 6,
      lineColor: "#000000",
      bgColor: "",
      resultImg: "",
      isCrop: false,
    };
  },
  methods: {
    handleReset() {
      // 清除
      this.$refs.esign.reset();
    },
    handleGenerate() {
      // 获取base64
      var _this = this;
      _this.$refs.esign
        .generate()
        .then((res) => {
          // 转成文件
          var file = _this.dataURLtoFile(res);
            console.log("file:",file )
          //调用接口
          uploadFile(file).then(({ data }) => {
           console.log("data:",data)
          });
        })
        .catch((err) => {
          _this.$toast(err); 
        });
    },
    // 将base64转换为file
    dataURLtoFile(dataurl) {
      let arr = dataurl.split(",");
      let mime = arr[0].match(/:(.*?);/)[1];
      let bytes = atob(arr[1]); // 解码base64
      let n = bytes.length;
      let ia = new Uint8Array(n);
      while (n--) {
        ia[n] = bytes.charCodeAt(n);
      }
      return new File([ia], "easign.jpg", { type: mime });
    },
  },
};
</script>
<style scoped>
.btn {
  display: flex;
  justify-content: space-around;
  margin-top: 10px;
}
</style>

vue移动端电子签名demo

html

<template>
    <div id='canvasBox'>
        <div ref="canvasBox">
             <canvas id="canvas" ref="canvas" height="150"></canvas>
        </div>
        <div class="row row-space-between">
          <button  @click="onClickCancle">取消</button>
          <button @click="clear">重签</button>
          <button @click="save">确认</button>
        </div>
        <!-- <img :src="singImgUrl" alt /> -->
    </div>
</template>

JS相关代码

<script>
var draw;
var preHandler = function(e) {
  e.preventDefault();
};
class Draw {
  constructor(el) {
    this.el = el;
    this.canvas = document.getElementById(this.el);
    this.cxt = this.canvas.getContext("2d");
    this.stage_info = canvas.getBoundingClientRect();
    this.path = {
      beginX: 0,
      beginY: 0,
      endX: 0,
      endY: 0
    };
  }
  init(btn) {
    var that = this;
    this.canvas.addEventListener("touchstart", function(event) {
      document.addEventListener("touchstart", preHandler, false);
      that.drawBegin(event);
    });
    this.canvas.addEventListener("touchend", function(event) {
      document.addEventListener("touchend", preHandler, false);
      that.drawEnd();
    });
    this.clear(btn);
  }
  drawBegin(e) {
    var that = this;
    window.getSelection()
      ? window.getSelection().removeAllRanges()
      : document.selection.empty();
    this.cxt.strokeStyle = "#BC4C2D";
    this.cxt.beginPath();
    this.cxt.moveTo(
      e.changedTouches[0].clientX - this.stage_info.left,
      e.changedTouches[0].clientY - this.stage_info.top
    );
    this.path.beginX = e.changedTouches[0].clientX - this.stage_info.left;
    this.path.beginY = e.changedTouches[0].clientY - this.stage_info.top;
    canvas.addEventListener("touchmove", function() {
      that.drawing(event);
    });
  }
  drawing(e) {
    this.cxt.lineTo(
      e.changedTouches[0].clientX - this.stage_info.left,
      e.changedTouches[0].clientY - this.stage_info.top
    );
    this.path.endX = e.changedTouches[0].clientX - this.stage_info.left;
    this.path.endY = e.changedTouches[0].clientY - this.stage_info.top;
    this.cxt.stroke();
  }
  drawEnd() {
    document.removeEventListener("touchstart", preHandler, false);
    document.removeEventListener("touchend", preHandler, false);
    document.removeEventListener("touchmove", preHandler, false);
    //canvas.ontouchmove = canvas.ontouchend = null
  }
  clear(btn) {
    this.base64Id = "";
    this.cxt.clearRect(0, 0, 500, 600);
  }
  save() {
    var blank = document.createElement("canvas"); //系统获取一个空canvas对象
    blank.width = canvas.width;
    blank.height = canvas.height;
    let flag = canvas.toDataURL("image/png") == blank.toDataURL(); //比较值相等则为空;
    if (flag) {
      return "0";
    } else {
      return canvas.toDataURL("image/png");
    }
  }
}
export default {
  data() {
    return {
      singImgUrl: ""
    };
  },
  methods: {
	 clear() {
        draw.clear();
        this.base64Id = "";
	 },
   	save() {
      var data = "";
      data = draw.save();
      if (data == "0") {
      		this.$toast("请先签名再点击确定哦~");
      } else {
	      this.singImgUrl = data;
	      ///data 就是得到的base64格式的签名图片,根据业务这里可上传到服务器
      }
      // 
    },
},
 mounted() {
 document.getElementById("canvasBox").addEventListener("touchmove", (e) => {
      e.preventDefault();
    });//阻止浏览器默认行为,防止签名浏览器下拉-------很重要
    this.base64Id = "";
    let _width = this.$refs.canvasBox.offsetWidth;
    this.$refs.canvas.width = _width; //适配移动端宽度给canvas
    draw = new Draw("canvas");
    draw.init();
  }
}
</script>

CSS 自行美化,相信大家都没得问题

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: vue vue-esign签字板的demo

本文链接: https://www.lsjlt.com/news/146756.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue vue-esign签字板的demo
    目录vue vue-esign签字板demo安装在main.js中全局引用vue移动端电子签名demovue vue-esign签字板demo 使用vue-esign让用户能够在手动...
    99+
    2022-11-13
  • vue vue-esign签字板的demo怎么实现
    本篇内容主要讲解“vue vue-esign签字板的demo怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue vue-esign签字板的demo怎么实现”吧!vu...
    99+
    2023-06-30
  • vue模板标签怎么用
    这篇文章将为大家详细讲解有关vue模板标签怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。模板标签的另一种用途该template标签可以在模板内的任何地方使用,以更好地组织代码。我喜欢用它来简化v-i...
    99+
    2023-06-27
  • vue给文字设置标签
    Vue.js 是一个轻量级的 JavaScript 框架,适用于构建响应式的 Web 应用程序。在 Vue 中,我们可以使用指令(directive)来对标签进行操作,从而实现对文字的标签设置。指令是 Vue 中用于自定义 HTML 标签的...
    99+
    2023-05-25
  • typescript在vue中的入门案例代码demo
    目录搜索框searchBox.vue首页Home.vue热门城市 popularCity.vue天气 weather.vuegetWeather.ts使用技术栈vue2+t...
    99+
    2022-12-30
    typescript案例代码 typescript入门demo
  • Vue怎么引入sign-canvas实现签名画板效果
    这篇“Vue怎么引入sign-canvas实现签名画板效果”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue怎么引入sig...
    99+
    2023-07-05
  • 拿来即用的vue旋转木马组件demo
    目录实现步骤1.确定组件类型2.选择实现方式3.功能需求分析4.话不多说,上代码实现步骤 1.确定组件类型 确定组件类型,如上图设计,标准的旋转木马组件 2.选择实现方式 1.1 ...
    99+
    2023-03-15
    vue旋转木马组件 vue组件
  • Vue如何解析带html标签的字符串为dom
    这篇文章给大家分享的是有关Vue如何解析带html标签的字符串为dom的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.场景描述如上接口中,content字段:content:&...
    99+
    2022-10-19
  • vue项目中扫码支付的实现示例(附demo)
    目录需求背景思路分析UI展示开始使用一 编写支付组件模板二 支付组件的JS相关代码和说明附:组件JS完整的源码需求背景 市场报告列表展示的报告有两种类型,一种是免费报告,另一种是付...
    99+
    2022-11-12
  • Vue折叠面板组件的封装
    本文实例为大家分享了Vue折叠面板组件的封装代码,供大家参考,具体内容如下 该组件使用了 Element 的一些 icon 图标,以及 过渡动画 el-collapse-transi...
    99+
    2022-11-13
  • vue中的模板语法是什么
    本文小编为大家详细介绍“vue中的模板语法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue中的模板语法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、模板语法模板语法分为插值语法和指令语法两种...
    99+
    2023-06-29
  • vue中如何给标签赋有标签的值
    Vue是一款流行的JavaScript框架,可以方便地构建交互式的用户界面。在Vue中,给标签赋值是一项基本的操作。本文将介绍如何在Vue中给标签赋值。在Vue中,给标签赋值的方法有很多种。下面介绍其中几种比较常见的方法:使用v-bind指...
    99+
    2023-05-14
  • vue-admin-template模板添加tagsview的实现
    目录一、从vue-element-admin复制文件二、修改 vue-admin-template\src\layout\components\AppMain.vue三、修改vue-...
    99+
    2022-11-13
  • Vue3中的模板语法和vue指令
    目录1 模板插值语法2 指令1 模板插值语法 在script 声明一个变量可以直接在template 使用用法为{{变量名称}}模板语法是可以编写条件运算的运算也是支持的操作API ...
    99+
    2022-11-13
    vue3模板语法 vue指令
  • vue模板编译的原理是什么
    这篇文章主要介绍了vue模板编译的原理是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue模板编译的原理是什么文章都会有所收获,下面我们一起来看看吧。vue提供了模板语法,允许我们声明式地描述状态和DOM...
    99+
    2023-07-05
  • vue使用H5的audio标签问题
    目录使用H5的audio标签vue中自定义audio总结使用H5的audio标签 template代码: <audio ref="audio" :src="audioUrl"&...
    99+
    2022-12-08
    vue使用H5 H5的audio标签 vue audio标签
  • 使用vue官方提供的模板vue-cli如何搭建一个helloWorld
    这篇文章主要介绍了使用vue官方提供的模板vue-cli如何搭建一个helloWorld,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。安装环...
    99+
    2022-10-19
  • vue字的颜色怎么改
    Vue.js是一种流行的JavaScript框架,被广泛用于开发现代Web应用程序。在Vue.js中,您可以轻松地更改文本字体颜色。本文将向您展示如何在Vue.js中更改文本字体颜色。第一步:使用v-bind绑定样式在Vue.js中,您可以...
    99+
    2023-05-14
  • vue的关键字有哪些
    vue中的关键字有:1.v-model,将标签的value值与vue实例中的data属性值进行绑定;2.v-on,通过配合具体的事件名来绑定Vue中定义的函数;3.v-bind,动态地绑定一个或多个特性;vue中的关键字有以下几种v-mod...
    99+
    2022-10-21
  • vue实现登录注册模板的方法
    这篇文章主要介绍了vue实现登录注册模板的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。模板1: login.vue<template><p&...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作