成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

開源推薦! 一款開箱即用的電子簽名組

開發 前端 開源
今天和大家分享一下我最近開源的輕量級電子簽名組件——React-sign2,我們可以使用它輕松的實現電子簽名, 比如說常用的合同簽字, 文稿簽名, 藝術簽名等, 并支持一鍵將簽名保存。

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

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

基本使用

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

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

然后一個簡單的使用如下:

import Sign from 'react-sign2';

export default () => 
  <Sign width={400} onDrawEnd={(c) => console.log(c)} />;

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

比如我可以調整線條的顏色:

調整線條寬度:

在具體使用的時候靈活配置即可, 我還提供了業務中經常用到的監聽事件, 方便使用者靈活調用:

  • onSave 保存時的回調。
  • onClear 當畫布清空時的回調。
  • onDrawEnd 每次繪制結束時的回調。

實現思路

按照筆者之前的習慣, 在設計組件之前都會先明確組件的設計需求, 然后根據健壯組件的設計原則來落地組件, 這里給大家分享一下我總結的幾條組件設計經驗:

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

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

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

這些都是組件第一個階段可以想到的配置點, 也是能應對第一階段業務需求的功能, 所以有了第一版的組件需求設計:

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

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

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

以上是組件的基本屬性定義和代碼結構, 畫圖部分涉及到 canvas 的比較細節的部分。

具體實現的源碼我已經上傳到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。
責任編輯:姜華 來源: 趣談前端
相關推薦

2023-01-29 07:49:57

2021-07-01 07:51:44

Vite管理模版

2015-06-30 09:49:19

管理平臺開源KVM

2024-08-19 09:25:42

2023-03-08 21:25:58

開源工具庫開箱

2021-06-09 09:52:29

開源Pyroscope代碼

2013-11-01 09:37:19

Android系統架構工具

2020-12-10 10:00:59

監控Java可視化

2025-05-15 08:35:00

2024-08-16 08:31:05

2019-08-02 14:45:22

阿里Java命令

2021-07-23 16:50:19

httpJava框架

2019-11-25 00:00:00

開源技術 數據

2020-08-28 10:40:13

PythonFaker數據

2021-11-24 09:12:11

Markdown編輯器Linux

2019-02-25 10:18:43

工具代碼測試

2021-08-31 15:53:48

Nuxt 開箱服務

2022-04-26 09:44:29

算法庫EasyCV開源

2016-02-15 11:44:23

源碼開源項目watch

2024-08-22 12:35:37

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 中文字幕亚洲欧美 | 中文字幕日韩欧美 | 国产精品大片 | 成人性视频免费网站 | 亚洲视频在线看 | 中文字幕一区二区三区不卡 | 亚洲欧美网站 | 91av导航| 四虎在线观看 | 一区二区三区视频在线 | 国产欧美一区二区三区另类精品 | 国产欧美日韩一区 | 亚洲一区| 精品国产乱码久久久久久牛牛 | 久久久久久成人 | 亚洲天堂男人的天堂 | 99热成人在线| 欧美黄色性生活视频 | 色视频网站在线观看 | 久久人人爽人人爽 | 在线视频a | 蜜桃臀av一区二区三区 | 艹逼网 | 国产精品一区一区三区 | 欧美精品日韩精品 | 欧美日韩国产一区二区三区 | 黄色一级片在线播放 | 一级日批片 | 一区二区三区免费观看 | 四色永久| 久久精彩视频 | 久久综合国产 | 欧美成人a∨高清免费观看 老司机午夜性大片 | 国产成人一区二区 | 日韩不卡一区二区三区 | 成人在线免费av | 日本一区二区在线视频 | 三级特黄特色视频 | 国产精品福利久久久 | 精品美女久久久久久免费 | 亚洲综合视频 |