jsPlumb学习笔记

自以为会了D3就可以无敌于可视化了,不过项目中却要求用jsPlumb。在我看来,这就是一个给元素画连接线的工具。

<!DOCTYPE html>
<html>
	<head>
		<title>jsPlumb</title>
		<style>
			.item{
				width:100px;
				height:50px;
				border:3px solid green;
				position: absolute;
			}
			.item1{
				left:400px;
				top:100px;
			}
			.item2{
				left:300px;
				top:250px;
			}
			.item3{
				left:500px;
				top:250px;
			}
			.item4{
				left:200px;
				top:400px;
			}
			.item5{
				left:400px;
				top:400px;
			}
			.item6{
				left:600px;
				top:400px;
			}
		</style>
	</head>
	<body>
		<div class=‘demo‘ id=‘demo‘>
			<div class=‘item item1‘ id=‘item1‘>1</div>
			<div class=‘item item2‘ id=‘item2‘>2</div>
			<div class=‘item item3‘ id=‘item3‘>3</div>
			<div class=‘item item4‘ id=‘item4‘>4</div>
			<div class=‘item item5‘ id=‘item5‘>5</div>
			<div class=‘item item6‘ id=‘item6‘>6</div>
		</div>
	<script src="jquery-2.1.1.js"></script>
	<script src="jquery-ui-1.9.2.js"></script>
	<script src="jquery.jsPlumb-1.4.1-all.js"></script>
	<script>
	jsPlumb.ready(function(){
		var color = ‘#222‘;
		var instance = jsPlumb.getInstance({
			//连线
			Connector:[‘Bezier‘, {curviness:50}],
			//拖动时的演示
			DragOptions:{cursor:‘pointer‘, zIndex:2000},
			//连接线的样式
			PaintStyle:{strokeStyle:‘steelblue‘, lineWidth:3},
			//连接点的样式
			EndpointStyle:{radius:6, fillStyle:‘#222‘},
			//hover时线样式
			HoverPaintStyle:{strokeStyle:‘green‘},
			//hover时点的样式
			EndpointHoverStyle:{fillStyle:‘red‘},
			Container:‘demo‘    //这里是container的id,而不是class。
		});
		instance.doWhileSuspended(function(){
			var arrowCommon = {foldback: .7, fillStyle: color, width: 14},
				overlays = [
				[‘Arrow‘, {location:.8}, arrowCommon],
				// [‘Arrow‘, {location:.3, direction:-1}, arrowCommon],
				];
			var windows = jsPlumb.getSelector(‘.item‘);

			for(var i = 0; i<windows.length;i++){
				instance.addEndpoint(windows[i], {
					uuid:windows[i].getAttribute(‘id‘)+‘-bottom‘,
					anchor:‘Bottom‘,
					maxConnections:-1
				});
				instance.addEndpoint(windows[i], {
					uuid:windows[i].getAttribute(‘id‘)+‘-top‘,
					anchor:‘Top‘,
					maxConnections:-1
				});
			}
			//connect 函数
			instance.connect({uuids:[‘item3-bottom‘,‘item6-top‘], overlays:overlays, detachable:true, reattach:true});
			instance.connect({uuids:[‘item1-bottom‘,‘item2-top‘], overlays:overlays});
			instance.connect({uuids:[‘item1-bottom‘,‘item3-top‘], overlays:overlays});
			instance.connect({uuids:[‘item2-bottom‘,‘item4-top‘], overlays:overlays});
			instance.connect({uuids:[‘item2-bottom‘,‘item5-top‘], overlays:overlays});
			//jquery ui里的draggable功能
			instance.draggable(windows);
		});
		jsPlumb.fire(‘jsPlumbdemoLoaded‘, instance);
	})
	</script>
	</body>
</html>

这是一个简单的小例子。是官网中一个demo的简化版,在学习了网上的教程之后,给官网的例子加了自己的注释。

给元素加连接点,给连接点加连接线,给连接线加各种装饰。需要的样式,canvas和SVG中都有,需要的动作,就是拖动。

时间: 2024-08-26 08:28:24

jsPlumb学习笔记的相关文章

前端流程图jsplumb学习笔记

1.这篇博客很好,另外两个是官网文档 http://www.cnblogs.com/leomYili/p/6346526.html https://jsplumbtoolkit.com/community/apidocs/classes/Connector.html https://jsplumbtoolkit.com/community/doc/connections.html#draganddrop 2.Jsplump流程图画虚线用"dashstyle": "2 4&qu

vector 学习笔记

vector 使用练习: /**************************************** * File Name: vector.cpp * Author: sky0917 * Created Time: 2014年04月27日 11:07:33 ****************************************/ #include <iostream> #include <vector> using namespace std; int main

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详细,自己在看它的文档和代码时写了一些demo和笔记,还有它实现的原理记录一下 学习Caliburn.Micro要有MEF和MVVM的基础 先说一下他的命名规则和引导类 以后我会把Caliburn.Micro的 Actions IResult,IHandle ICondu

jQuery学习笔记(一):入门

jQuery学习笔记(一):入门 一.JQuery是什么 JQuery是什么?始终是萦绕在我心中的一个问题: 借鉴网上同学们的总结,可以从以下几个方面观察. 不使用JQuery时获取DOM文本的操作如下: 1 document.getElementById('info').value = 'Hello World!'; 使用JQuery时获取DOM文本操作如下: 1 $('#info').val('Hello World!'); 嗯,可以看出,使用JQuery的优势之一是可以使代码更加简练,使开

[原创]java WEB学习笔记93:Hibernate学习之路---Hibernate 缓存介绍,缓存级别,使用二级缓存的情况,二级缓存的架构集合缓存,二级缓存的并发策略,实现步骤,集合缓存,查询缓存,时间戳缓存

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

Activiti 学习笔记记录(三)

上一篇:Activiti 学习笔记记录(二) 导读:上一篇学习了bpmn 画图的常用图形标记.那如何用它们组成一个可用文件呢? 我们知道 bpmn 其实是一个xml 文件

HTML&CSS基础学习笔记8-预格式文本

<pre>标签的主要作用是预格式化文本.被包围在 pre 标签中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. <pre>标签的一个常见应用就是用来表示计算机的源代码.当然你也可以在你需要在网页中预显示格式时使用它. 会使你的文本换行的标签(例如<h>.<p>)绝不能包含在 <pre> 所定义的块里.尽管有些浏览器会把段落结束标签解释为简单地换行,但是这种行为在所有浏览器上并不都是一样的. 更多学习内容,就在码芽网http://www.

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl

[原创]java WEB学习笔记48:其他的Servlet 监听器:域对象中属性的变更的事件监听器 (3 个),感知 Session 绑定的事件监听器(2个)

本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 ---------------------------------