前言

jsPlumb是一款開源軟體,但jsPlumb toolkit是收費的。

本文主要使用jsPlumb實現一些簡單的流程設計功能。

基礎學習

首先引入jsplumb.min.js。

  1. <script src="https://cdn.jsdelivr.net/npm/jsplumb@2.8.0/dist/js/jsplumb.min.js"></script>

然後編寫程式碼如下:

  1. <html lang="en">

  2. <head>
  3. <meta charset="UTF-8">
  4. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  5. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  6. <title>Document</title>
  7. <style>
  8. #diagramContainer {
  9. padding: 20px;
  10. width: 80%;
  11. height: 200px;
  12. border: 1px solid gray;
  13. }

  14. .item {
  15. height: 80px;
  16. width: 80px;
  17. border: 1px solid blue;
  18. float: left;
  19. }
  20. </style>
  21. </head>

  22. <body>
  23. <div id="diagramContainer">
  24. <div id="item_left" class="item"></div>
  25. <div id="item_right" class="item" style="margin-left:50px;"></div>
  26. </div>
  27. <script src="https://cdn.jsdelivr.net/npm/jsplumb@2.8.0/dist/js/jsplumb.min.js"></script>

  28. <script>
  29. /* global jsPlumb */
  30. jsPlumb.ready(function () {
  31. jsPlumb.connect({
  32. source: 'item_left',
  33. target: 'item_right',
  34. endpoint: 'Dot'
  35. })
  36. })
  37. </script>
  38. </body>

  39. </html>

效果圖如下:

可以看到,我們定義了一個容器diagramContainer,和兩個div塊元素,然後通過jsPlumb的connect連線函式,將兩個正方形,連線到了一起。

基礎學習參考網站:https://github.com/wangduanduan/jsplumb-chinese-tutorial

流程設計器開發

首先設計Html元素,設計一個左側功能列表區域,一個右側流程設計區域。

然後再設計三個節點拖進設計區域後釋放時的樣式。

程式碼如下:

  1. <div id="app">
  2. <div class="container-fluid">
  3. <div class="row">
  4. <div id="side-buttons" class="col-md-1 bg-info min-height ">
  5. <div style="text-align:center;">
  6. <h2 class="mt20 ">節點列表</h2>
  7. <hr />
  8. <a class="btn btn-success btn-controler btnw" href="#" data-template="tpl-Normal" role="button">
  9. <i class="fa fa-square" aria-hidden="true"></i>
  10. 節點
  11. </a>
  12. <hr />
  13. <a id="export" class="btn btn-success mt10 btnw" href="#" role="button">
  14. <i class="fa fa-file-text-o" aria-hidden="true"></i>
  15. 匯出
  16. </a>
  17. </div>
  18. </div>
  19. <div class="min-height">
  20. <div class="title"><p>提示:雙擊連線線可刪除連線。</p></div>
  21. <div id="drop-bg" class="col-md-11 bg-success min-height">

  22. </div>
  23. </div>
  24. </div>
  25. </div>
  26. </div>

  27. <script id="tpl-Normal" type="text/html">
  28. <div class='pa' id='{{id}}' style='top:{{top}}px;left:{{left}}px; opacity: 0.6;'>

  29. <a class='btn btn-default' href='#' role='button'>
  30. <div>
  31. <input type="text" value="{{comment}}" tag="{{id}}" class="nodeText" />

  32. <span class="delete-node pull-right" data-type="deleteNode" data-id="{{id}}" style="font-size:10px;margin:0 -10px 0 0">X</span>
  33. @*<span class="add-node pull-right" data-type="addDragNode" data-id="{{id}}" style="font-size:10px;margin:0 5px 0 0">+</span>*@
  34. </div>
  35. </a>
  36. </div>
  37. </script>

  38. <script id="tpl-Root" type="text/html">
  39. <div class='pa' id='{{id}}' style='top:{{top}}px;left:{{left}}px;opacity: 0.6;'>
  40. <a class='btn btn-success' href='#' role='button'>
  41. <div style="width:80px;height:30px;line-height:35px">
  42. {{comment}}
  43. @*<span class="delete-node pull-right" data-type="deleteNode" data-id="{{id}}">X</span>*@
  44. </div>
  45. </a>
  46. </div>
  47. </script>

  48. <script id="tpl-Exit" type="text/html">
  49. <div class='pa' id='{{id}}' style='top:{{top}}px;left:{{left}}px'>
  50. <a class='btn btn-danger' href='#' role='button'>
  51. <div style="width:80px;height:30px;line-height:35px">
  52. {{comment}}
  53. @*<span class="delete-node pull-right" data-type="deleteNode" data-id="{{id}}">X</span>*@
  54. </div>
  55. </a>
  56. </div>
  57. </script>

頁面效果如下:

然後編寫程式碼實現拖拽和釋放的功能。

核心程式碼如下:

  1.  
  1. jsPlumb.ready(
  2. function () {
  3. console.log("main-start")
  4. jsPlumb.setContainer('diagramContainer')
  5.  
  6. $('.btn-controler').draggable({
  7. helper: 'clone',
  8. scope: 'ss'
  9. })

  10. $(areaId).droppable({
  11. scope: 'ss',
  12. drop: function (event, ui) {
  13. dropNode(ui.draggable[0].dataset.template, ui.position)
  14. }
  15. })

  16. $('#app').on('click', function (event) {
  17.  
  18. event.stopPropagation()
  19. event.preventDefault()
  20. var item = event.target.dataset
  21.  
  22. if (item.type === 'deleteNode') {
  23. var index = -1;
  24. data.nodeList.forEach(function (node, i) {
  25. if (node.id == item.id) {
  26. index = i;
  27. }
  28. })
  29. data.nodeList.splice(index, 1);
  30. console.log(data.nodeList)
  31. jsPlumb.remove(item.id)
  32. }
  33.  
  34. })
  35.  
  36. // 單點選了連線線上的X號
  37. jsPlumb.bind('dblclick', function (conn, originalEvent) {
  38. DataDraw.deleteLine(conn)
  39. })
  40.  
  41. // 當連結建立
  42. jsPlumb.bind('beforeDrop', function (info) {
  43. console.log("beforeDrop")
  44. console.log(info)
  45. var isSame = false;
  46. data.nodeList.forEach(function (node) {
  47. if (info.sourceId == node.id) {
  48. if (!node.data) {
  49. node.data = []
  50. var nextNode = {
  51. "nextNode": info.targetId
  52. }
  53. node.data.push(nextNode)
  54. }
  55. else {
  56.  
  57. node.data.forEach(function (dItem){
  58. if (dItem.nextNode == info.targetId) {
  59. isSame = true;
  60. return;
  61. }
  62. })
  63. if (!isSame) {
  64. var nextNode = {
  65. "nextNode": info.targetId
  66. }
  67. node.data.push(nextNode)
  68. }
  69.  
  70. }
  71.  
  72. }

  73. })
  74. if (!isSame) {
  75. console.log(data.nodeList)
  76. return connectionBeforeDropCheck(info)
  77. }
  78. else {
  79. console.log("節點相同")
  80. return
  81. }
  82. })
  83. console.log("main-DataDraw.draw")
  84. DataDraw.draw(data.nodeList)
  85. console.log("初始化節點文字事件")
  86. initNodeTextEvent();
  87.  
  88. })

jsPlumb函式:

setContainer:設定容器。

droppable:指定該區域支援拖拽的控制元件。

draggable:指定該按鈕可以被拖拽。

自定義函式:

DataDraw.draw初始化節點。

initNodeTextEvent設計圖中的節點中的節點名稱變化,同步到節點列表陣列物件中,實現資料同步。

頁面初始化時讀取了data.js檔案中的起始配置節點的資料。

data.js檔案如下:

  1. var data = {
  2. 'nodeList': [{ "id": "Start", "type": "Root", "comment": "開始", "top": 50, "left": 150, "data": [{ "nextNode": "81422cf0-00ae-11ec-b359-c13e24702355" }, { "nextNode": "779c8300-00b1-11ec-923c-fbdaa48876a6" }] }, { "id": "e1a3de30-0096-11ec-b888-ddd94967488d", "comment": "22", "top": 198, "left": 566, "type": "Normal", "data": [{ "nextNode": "Exit" }] }, { "id": "81422cf0-00ae-11ec-b359-c13e24702355", "comment": "1", "top": 634, "left": 432, "type": "Normal", "data": [{ "nextNode": "Exit" }] }, { "id": "84689a40-00ae-11ec-b359-c13e24702355", "comment": "2", "top": 628, "left": 198, "type": "Normal", "data": [{ "nextNode": "Exit" }] }, { "id": "779c8300-00b1-11ec-923c-fbdaa48876a6", "comment": "", "top": 891, "left": 617, "type": "Normal" }, { "id": "Exit", "type": "Exit", "comment": "結束", "top": 818, "left": 929 }, { "id": "a57fe0d0-00b3-11ec-99d4-39fb5d424f70", "comment": "", "top": 316, "left": 1130, "type": "Normal" }]
  3. }

這樣我們就實現了基礎的流程設計器了,下面我們看一下功能。

刪除

點選連結線可以刪除連結,如下圖:

拖拽

拖拽節點按鈕到設計器區域,如下圖:

匯出

點選匯出按鈕將當前流程的節點資訊匯出成json字串,如下圖

可以看到,設計器是支援一個節點發射出多個連結線的。

在匯出時,我們再設計器中修改的節點名,也被同步的匯出到json字串中了。

----------------------------------------------------------------------------------------------------

到此,jsPlumb開發流程設計器就已經介紹完了。

程式碼已經傳到Github上了,歡迎大家下載。

Github地址: https://github.com/kiba518/KibaWorkFlowDesigner_JS

----------------------------------------------------------------------------------------------------

注:此文章為原創,任何形式的轉載都請聯絡作者獲得授權並註明出處!
若您覺得這篇文章還不錯,請點選下方的【推薦】,非常感謝!

https://www.cnblogs.com/kiba/p/15293054.html