当我尝试将'right'属性从px中的值更改为以百分比表示的值时,我遇到了jquery-ui switchClass完成的动画问题。问题仅发生在Chrome下(在FireFox或IE下运行)。
动画应该只将div的右侧属性从“90px”更改为“20%”,但div首先会转到屏幕的另一部分。当我查看调试器工具时,px似乎被解释为%:值的序列是90px,89%,88%,... 21%,20%。
以下代码重现了该问题:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.8.21/jquery-ui.min.js"></script>
<style>
.class1 {width:100px; height:50px; position:absolute; right:90px; background-color:#F9EDBE;}
.class2 {width:100px; height:50px; position:absolute; right:20%; background-color:#F9EDBE;}
</style>
</head>
<body>
<div id="myDiv" class="class1" onclick="$('#myDiv').switchClass('class1', 'class2', 5000);">Click me</div>
</body>
提前感谢您的帮助。
答案 0 :(得分:0)
您可以尝试使用'this'而不是jQuery选择器。还要尝试添加'name'属性,其值与'id'相同。