【发布时间】:2012-10-10 05:39:17
【问题描述】:
我一直在尝试在画布上制作一个漂亮的可编辑多边形,使用 jQuery UI 来抓取顶点并移动它们。这在 Chrome、Firefox 和 Safari 上运行良好,但在 IE9 上运行不佳。
http://jsfiddle.net/EveryoneMustWin/qNdCw/
CSS
.vertex {width:50px; height:50px; border:0px dotted red; position:absolute; display:none; z-index:0;}
#vertexcontainer .vertex {display:block;}
.vertex div.handle {width:40px; height:40px; position:relative; left:-20px; top:-20px; border:1px solid red; border-radius:20px;z-index:1; opacity:0.5;}
.currenthandle {width:40px; height:40px; border:1px solid red; position:absolute; background-color:#fc0;}
代码
$( ".vertex" ).draggable({
stack: "div",
snap: true,
handle: "div.handle",
start: function() {
$(".currenthandle").removeClass("currenthandle");
$(this).children("div.handle").addClass("currenthandle");
},
drag: function() {
drawPoly();
},
stop: function() {
drawPoly();
}
});
顶点手柄的可拖动区域似乎很小,如果幸运的话,您可以通过单击手柄的边框来选择它。一旦您选择了顶点,就可以很好地拖动它们,因此核心可拖动行为不是问题。
我的猜测是 jQuery UI 将“.vertex div.handle”的 element.style 设置为不合适的设置。还是 CSS3 的 IE9 问题?在没有元素检查器的情况下,我不太擅长在 IE 中调查这类问题。感谢您的任何提示!
【问题讨论】:
-
这件事似乎很熟悉。问题似乎是在 IE 中,您无法选择
div.handle内容,因为它们是“空的”。 -
例如:jsfiddle.net/qNdCw/6 给它一个背景色,你就“无家可归”了。
-
这看起来确实是一个修复!你想把它作为答案发布,我会接受吗?你认为这是我应该向 jQuery UI 开发人员报告的吗?非常感谢。
-
这是一个 jQuery 问题;这是一个 IE 显示(故障?错误?故意戳眼睛?),呃,问题。我假设你可以模拟它,将一个像素的透明
gif设置为background-image。我认为这会通过让 IE 认为有一个实际的背景来接受鼠标点击来“解决”这个问题。 -
上面那条评论应该说“这不是 jQuery 问题”。
标签: jquery jquery-ui html5-canvas internet-explorer-9 jquery-ui-draggable