日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
開源推薦!一款開箱即用的電子簽名組

hello, 大家好, 我是徐夕, 今天又到了分享時(shí)間. 今天和大家分享一下我最近開源的輕量級電子簽名組件——react-sign2。

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信平臺小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了石阡免費(fèi)建站歡迎大家使用!

我們可以使用它輕松的實(shí)現(xiàn)電子簽名, 比如說常用的合同簽字, 文稿簽名, 藝術(shù)簽名等, 并支持一鍵將簽名保存。

基本使用

我們要想直接使用, 可以在 npm 上安裝 react-sign2 :

# 或者yarn add react-sign2
npm i react-sign2

然后一個(gè)簡單的使用如下:

import Sign from 'react-sign2';

export default () => 
   console.log(c)} />;

react-sign2還提供了很多可定制的屬性, 來方便使用者靈活定制電子簽名, 以下是開放性屬性介紹:

比如我可以調(diào)整線條的顏色:

調(diào)整線條寬度:

在具體使用的時(shí)候靈活配置即可, 我還提供了業(yè)務(wù)中經(jīng)常用到的監(jiān)聽事件, 方便使用者靈活調(diào)用:

  • onSave 保存時(shí)的回調(diào)。
  • onClear 當(dāng)畫布清空時(shí)的回調(diào)。
  • onDrawEnd 每次繪制結(jié)束時(shí)的回調(diào)。

實(shí)現(xiàn)思路

按照筆者之前的習(xí)慣, 在設(shè)計(jì)組件之前都會(huì)先明確組件的設(shè)計(jì)需求, 然后根據(jù)健壯組件的設(shè)計(jì)原則來落地組件, 這里給大家分享一下我總結(jié)的幾條組件設(shè)計(jì)經(jīng)驗(yàn):

  • 對組件進(jìn)行嚴(yán)格的屬性設(shè)計(jì), 保證業(yè)務(wù)層能低成本使用組件, 并保持一定的可配性。
  • 組件內(nèi)外部類型約定(ts規(guī)范), 并提供對邏輯的兼容性。
  • 可讀性(代碼格式統(tǒng)一清晰,注釋完整,代碼結(jié)構(gòu)層次分明,編程范式使用得當(dāng))。
  • 可用性(代碼功能完整,在不同場景都能很好兼容,業(yè)務(wù)邏輯覆蓋率)。
  • 復(fù)用性(代碼可以很好的被其他業(yè)務(wù)模塊復(fù)用)。
  • 可維護(hù)性(代碼易于維護(hù)和擴(kuò)展,并有一定的向下/向上兼容性)。
  • 高性能(組件具有一定的性能, 如復(fù)雜場景的渲染, 計(jì)算等)。

對于電子簽名組件, 我們最小化的需求就是能滿足用戶的線上簽名, 并能保存簽名數(shù)據(jù)。

以上就是我們最小化的需求, 為了滿足我總結(jié)的組件設(shè)計(jì)幾大原則, 我們需要對組件進(jìn)行近一步的需求分析: 簽名的顏色, 筆觸的粗細(xì), 平滑度, 支持自定義事件等。

這些都是組件第一個(gè)階段可以想到的配置點(diǎn), 也是能應(yīng)對第一階段業(yè)務(wù)需求的功能, 所以有了第一版的組件需求設(shè)計(jì):

接下來就需要用 typescript 來規(guī)范組件的輸入和輸出了. 具體定義如下:

export interface IProp {
  /**
   * @description   畫布寬度
   * @default       400
   */
   width?: number;
   /**
    * @description   畫布高度
    * @default       200
    */
   height?: number;
   /**
    * @description   線寬
    * @default       4
   */
   lineWidth?: number;
   /**
    * @description   線段顏色
    * @default       'red'
   */
   strokeColor?: string;
   /**
    * @description   設(shè)置線條兩端圓角
    * @default       'round'
   */
   lineCap?: string;
   /**
    * @description   線條交匯處圓角
    * @default       'round'
   */
   lineJoin?: string;
   /**
    * @description   畫布背景顏色
    * @default       'transparent'
   */
   bgColor?: string;
   /**
    * @description   true
   */
   showBtn?: boolean;
   /**
   * @description   當(dāng)保存時(shí)的回調(diào), blob為生成的圖片bob
   * @default       -
   */
   onSave?: (blob: Blob) => void;
  /**
   * @description   當(dāng)畫布清空時(shí)的回調(diào), 參數(shù)為畫布的上下文對象,可以直接使用canvas的api
   * @default       -
   */
   onClear?: (canvasContext: CanvasRenderingContext2D) => void;
   /**
   * @description   當(dāng)畫布結(jié)束時(shí)的回調(diào)
   * @default       -
   */
   onDrawEnd?: (canvas: HTMLCanvasElement) => void;
}

接下來就到了我們具體的代碼實(shí)現(xiàn)階段. 由于電子簽名的核心技術(shù)采用的是canvas(雖然用dom和svg也可以實(shí)現(xiàn)), 所以無論你是用的react還是vue3, 或者似乎原生態(tài)javascript, 都能低成本的封裝. 這里筆者采用全球程序員最愛用的react 來實(shí)現(xiàn)。

以上是組件的基本屬性定義和代碼結(jié)構(gòu), 畫圖部分涉及到 canvas 的比較細(xì)節(jié)的部分。

具體實(shí)現(xiàn)的源碼我已經(jīng)上傳到github, 感興趣的朋友大家可以參考一下。

github: https://github.com/MrXujiang/react-sign

大家如果想直接使用, 可以使用如下方式安裝使用:

react-sign2 官方演示文檔

參考資料

  1. https://developer.mozilla.org/zh-CN/docs/Web/API/Canvas_API。
  2. https://juejin.cn/post/7174251833773752350。

當(dāng)前文章:開源推薦!一款開箱即用的電子簽名組
分享路徑:http://m.5511xx.com/article/cohgjji.html