0

当我尝试将 '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>

在此先感谢您的帮助。

4

1 回答 1

0

您可以尝试使用 'this' 而不是 jQuery 选择器。还尝试添加与“id”具有相同值的“name”属性。

于 2012-07-26T08:41:09.047 回答