Ответ 1
Пока я действительно пытаюсь найти подходящий метод для этого (что привело меня к вашему вопросу). У меня есть решение, которое я использую в то же время, чтобы заставить jsPlumb работать так, как я хочу.
В принципе, вам нужно добавить нулевой диапазон высоты/ширины, чтобы действовать как промежуточный node. Затем вы выполняете соединения с и из этого node вместо прямого между реальными элементами.
Я изменил ваш jsfiddle (обновленная ссылка) чтобы привести пример этого.
Важно отметить способность устанавливать размещение якоря с использованием координат и возможность использовать две разные формы конечных точек. Кроме того, поскольку длина по умолчанию от привязки до первого поворота слишком велика в вашем примере, ее можно контролировать с помощью аргумента stub.
Ниже приведены соответствующие изменения с комментариями.
HTML
<div id="root">
<div class="item" id="item1">Item 1</div>
<div class="item" id="item2">Item 2</div>
<div class="item" id="item3">Item 3</div>
<div class="item" id="item4">Item 4</div>
<div class="item" id="item5">Item 5</div>
<div class="item" id="item6">Item 6</div>
<div class="item" id="item7">Item 7</div>
<div class="node" id="8-12"></div> <!-- Midpoint -->
<div class="item" id="item8">Item 8</div>
<div class="item" id="item9">Item 9</div>
<div class="item" id="item10">Item 10</div>
<div class="item" id="item11">Item 11</div>
<div class="item" id="item12">Item 12</div>
<div class="item" id="item13">Item 13</div>
<div class="item" id="item14">Item 14</div>
</div>
CSS
.node {
position: absolute;
height: 0px;
width: 0px;
visibility: hidden;
/* change these to place the midpoint properly */
left: 285px;
top: 160px;
}
JS
//connection from item8 to midpoint(8-12)
jsPlumb.connect({
source: $('#item8'),
target: $('#8-12'),
connector:[ "Flowchart", {stub:5} ], //<== set stub length to be
// as short as you need it
paintStyle: {
strokeStyle: "#000000",
lineWidth:1
},
anchors:[ [0,0.5,-1,0],[0.5,0,0,-1] ], //<== connection position/direction
endpoints:[ ["Dot", {radius:2}],["Blank"] ] //<== Blank connector at end
});
//connection from midpoint(8-12) to item12
jsPlumb.connect({
source: $('#8-12'),
target: $('#item12'),
connector:[ "Flowchart", {stub:5} ], //<== set stub length to be
// as short as you need it
paintStyle: {
strokeStyle: "#000000",
lineWidth:1
},
anchors:[ [0,0.5,-1,0],[0.5,0,0,-1] ], //<== connection position/direction
endpoints:[ ["Blank"],["Dot", {radius:2}] ] //<== Blank connector at start
});