欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue?vue-esign簽字板的demo

 更新時(shí)間:2022年04月21日 10:56:57   作者:今天代碼敲了嗎  
這篇文章主要介紹了vue?vue-esign簽字板的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue vue-esign簽字板demo

使用vue-esign讓用戶能夠在手動(dòng)簽字并返回為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) => {
? ? ? ? ? // 轉(zhuǎn)成文件
? ? ? ? ? var file = _this.dataURLtoFile(res);
? ? ? ? ? ? console.log("file:",file )
? ? ? ? ? //調(diào)用接口
? ? ? ? ? uploadFile(file).then(({ data }) => {
? ? ? ? ? ?console.log("data:",data)
? ? ? ? ? });
? ? ? ? })
? ? ? ? .catch((err) => {
? ? ? ? ? _this.$toast(err);?
? ? ? ? });
? ? },
? ? // 將base64轉(zhuǎn)換為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移動(dòng)端電子簽名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">確認(rèn)</button>
?? ??? ?</div>
?? ??? ?<!-- <img :src="singImgUrl" alt /> -->
?? ?</div>
</template>

JS相關(guān)代碼

<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"); //系統(tǒng)獲取一個(gè)空canvas對(duì)象
    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("請(qǐng)先簽名再點(diǎn)擊確定哦~");
      } else {
	      this.singImgUrl = data;
	      ///data 就是得到的base64格式的簽名圖片,根據(jù)業(yè)務(wù)這里可上傳到服務(wù)器
      }
      // 
    },
},
 mounted() {
 document.getElementById("canvasBox").addEventListener("touchmove", (e) => {
      e.preventDefault();
    });//阻止瀏覽器默認(rèn)行為,防止簽名瀏覽器下拉-------很重要
    this.base64Id = "";
    let _width = this.$refs.canvasBox.offsetWidth;
    this.$refs.canvas.width = _width; //適配移動(dòng)端寬度給canvas
    draw = new Draw("canvas");
    draw.init();
  }
}
</script>

CSS 自行美化,相信大家都沒(méi)得問(wèn)題

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue+axios+java實(shí)現(xiàn)文件上傳功能

    vue+axios+java實(shí)現(xiàn)文件上傳功能

    這篇文章主要為大家詳細(xì)介紹了vue+axios+java實(shí)現(xiàn)文件上傳功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Vue過(guò)濾器filters如何使用

    Vue過(guò)濾器filters如何使用

    Vue過(guò)濾器filters用于一些常見(jiàn)的文本格式化,通過(guò)過(guò)濾器可以進(jìn)行處理成自己想要展示出來(lái)的格式,由“管道”符號(hào)指示,本文給大家介紹Vue過(guò)濾器filters使用方式,感興趣的朋友一起看看吧
    2023-10-10
  • Vue路由的懶加載深入詳解

    Vue路由的懶加載深入詳解

    這篇文章主要介紹了vue-router路由懶加載及實(shí)現(xiàn)方式,路由懶加載的主要作用是將?路由對(duì)應(yīng)的組件打包成一個(gè)個(gè)的js代碼塊,只有在這個(gè)路由被訪問(wèn)到的時(shí)候,才會(huì)加載對(duì)應(yīng)組件的代碼塊,需要的朋友可以參考下
    2022-12-12
  • elementui中tabel組件的scope.$index的使用及說(shuō)明

    elementui中tabel組件的scope.$index的使用及說(shuō)明

    這篇文章主要介紹了elementui中tabel組件的scope.$index的使用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue實(shí)現(xiàn)標(biāo)簽云效果的示例

    vue實(shí)現(xiàn)標(biāo)簽云效果的示例

    這篇文章主要介紹了vue實(shí)現(xiàn)標(biāo)簽云效果的示例,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-11-11
  • 解決vue熱替換失效的根本原因

    解決vue熱替換失效的根本原因

    今天小編就為大家分享一篇解決vue熱替換失效的根本原因,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • 解決Vue 瀏覽器后退無(wú)法觸發(fā)beforeRouteLeave的問(wèn)題

    解決Vue 瀏覽器后退無(wú)法觸發(fā)beforeRouteLeave的問(wèn)題

    這篇文章主要介紹了解決Vue 瀏覽器后退無(wú)法觸發(fā)beforeRouteLeave的問(wèn)題,需要的朋友可以參考下
    2017-12-12
  • 淺析Vue3中的邏輯復(fù)用

    淺析Vue3中的邏輯復(fù)用

    這篇文章主要為大家詳細(xì)介紹了Vue3中邏輯復(fù)用的相關(guān)知識(shí),文中的示例代碼簡(jiǎn)潔易懂,對(duì)我們深入了解Vue3有一定的幫助,需要的小伙伴可以參考下
    2023-12-12
  • vue.js中導(dǎo)出Excel表格的案例分析

    vue.js中導(dǎo)出Excel表格的案例分析

    這篇文章主要介紹了vue.js中如何導(dǎo)出Excel表格,在項(xiàng)目中經(jīng)常會(huì)遇到這樣的需求,今天小編分步驟通過(guò)實(shí)例代碼給大家詳細(xì)介紹,需要的朋友可以參考下
    2019-06-06
  • 淺析vue中的組件傳值

    淺析vue中的組件傳值

    這篇文章主要介紹了淺析vue中的組件傳值,文章基于vue的相關(guān)資料展開(kāi)對(duì)主題的詳細(xì)介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-04-04

最新評(píng)論