当我尝试将 'right' 属性从以 px 为单位的值更改为以百分比为单位的值时,我遇到了 jquery-ui switchClass 完成的动画问题。该问题仅在 Chrome 下发生(在 FireFox 或 IE 下工作)。
动画应该只是将 div 的 right 属性从“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>
在此先感谢您的帮助。