错误:无效值为
问题描述:
我有一个函数可以在两个divs
之间创建一个以模态显示的行。错误:无效值为<svg>属性width =“ - Infinity”jsPlumb
//A function that creates line instance.
function myid_create_line_instance(){
jsPlumb_instance[0] = jsPlumb.getInstance();
var id1 = 'tpl_preview_line_1_pair_1';
var id2 = 'tpl_preview_line_1_pair_2';
var endpointOptions = {
anchor:'BottomCenter',
maxConnections:1,
endpoint:['Rectangle',{width:'1px', height:'1px' }],
paintStyle:{fillStyle:'#00000', dashstyle:'3 3'},
connectorStyle:{lineWidth:'1px',strokeStyle:'#000000'},
connector:['Straight'],
};
div1Endpoint = jsPlumb_instance[0].addEndpoint(id1, endpointOptions);
div2Endpoint = jsPlumb_instance[0].addEndpoint(id2, endpointOptions);
jsPlumb_instance[0].connect({
source:div1Endpoint,
target:div2Endpoint,
});
jsPlumb_instance[0].draggable(id1);
jsPlumb_instance[0].draggable(id2);
}
执行代码后,将其抛出2错误:
Error: Invalid value for <svg> attribute width="-Infinity" jsPlumb-
2.1.2.js?o9evom:12902
_attr jsPlumb-2.1.2.js?o9evom:12902
paint jsPlumb-2.1.2.js?o9evom:13086
_ju.extend.paint jsPlumb-2.1.2.js?o9evom:8626
(anonymous function) jsPlumb-2.1.2.js?o9evom:2692
redraw jsPlumb-2.1.2.js?o9evom:9322
_draw jsPlumb-2.1.2.js?o9evom:3649
_currentInstance.finaliseConnection jsPlumb-2.1.2.js?o9evom:3926
connect jsPlumb-2.1.2.js?o9evom:4253
myid_create_line_instance myid_templates.js?o9evom:4614
myid_template_display_line myid_templates.js?o9evom:2215
jQuery.fn.myid_choose_template myid_templates.js?o9evom:4812
Drupal.ajax.commands.invoke ajax.js?v=7.34:608
Drupal.ajax.success ajax.js?v=7.34:400
ajax.options.success ajax.js?v=7.34:164
c jquery-1.10.2.js:3048
p.fireWith jquery-1.10.2.js:3160
k jquery-1.10.2.js:8235
r jquery-1.10.2.js:8778
第二错误:
Error: Invalid value for <svg> attribute height="-Infinity" jsPlumb-2.1.2.js?o9evom:12902
_attr jsPlumb-2.1.2.js?o9evom:12902
paint jsPlumb-2.1.2.js?o9evom:13086
_ju.extend.paint jsPlumb-2.1.2.js?o9evom:8626
(anonymous function) jsPlumb-2.1.2.js?o9evom:2692
redraw jsPlumb-2.1.2.js?o9evom:9322
_draw jsPlumb-2.1.2.js?o9evom:3649
_currentInstance.finaliseConnection jsPlumb-2.1.2.js?o9evom:3926
connect jsPlumb-2.1.2.js?o9evom:4253
myid_create_line_instance myid_templates.js?o9evom:4614
myid_template_display_line myid_templates.js?o9evom:2215
jQuery.fn.myid_choose_template myid_templates.js?o9evom:4812
Drupal.ajax.commands.invoke ajax.js?v=7.34:608
Drupal.ajax.success ajax.js?v=7.34:400
ajax.options.success ajax.js?v=7.34:164
c jquery-1.10.2.js:3048
p.fireWith jquery-1.10.2.js:3160
k jquery-1.10.2.js:8235
r jquery-1.10.2.js:8778
我尝试的下面jsPlumb初始化后右代码的第一行;然后连接两个div后,下面的第二行代码,没有运气。
jsPlumb_instance[0].setSuspendDrawing(true);
jsPlumb_instance[0].setSuspendDrawing(false, true);
我甚至尝试了批处理方法,但没有什么改变。
jsPlumb_instance[0].batch(function() {
//Codes about connecting the two points of line.
}, false);
我注意到的一件事是应该连接我的模态中的两个点的线没有在模态中找到。请参见下面的图片:
我也尝试下面的代码,但仍时有发生的问题。
jsPlumb_instance[id].repaintEverything();
答
我遇到了同样的错误,当我的容器没有任何大小。我可以假设你应该为jsPlumb实例明确指定容器:
jsPlumb.getInstance({ Container:"editor" });
+0
感谢您的回答。它为我工作。 –
你有一个小提琴或plnkr,我们可以作为一个工作的例子吗?您是否查看了jsPlumb-2.1.2.js的12902行? – Twisty