javascript – 如何避免兄弟的元素抖动时动画与jquery

我有两个div元素并排.当我将鼠标移动到第一个位置并使其动画时,下一个奇怪的是摇动.看到这里: http://jsfiddle.net/YqZSv/1/我注意到只有当填充和边框涉及时才会发生.如果我用边框替换边框,则“晃动”效果停止.

HTML

<div class='a'></div>
<div class='b'></div>

CSS

.a {
   width: 80px;
   height: 80px;
   padding: 10px;
   border: 0px solid yellow;
   background-color: red;
   display: inline-block
}

.b {
   width: 100px;
   height: 100px;
   background-color: blue;
   display: inline-block;
   margin-left: 20px;
}

jQuery的

$('.a').mouseenter(function(){
    $(this).animate({
        'padding': 0,'borderWidth': 10
    });
}).mouseleave(function(){
    $(this).animate({
       'padding': 10,'borderWidth': 0
    });
});

我不能使用边框而不是边框​​,因为我使用带有边框起点的背景图像,所以我不希望它与其内容一起移动.

任何帮助?

解决方法

告诉浏览器将填充和边框宽度保持在定义的高度/宽度内,因此不会认为大小正在更改:
div.a { Box-sizing:border-Box; }

http://jsfiddle.net/exvEa/

相关文章

页面搜索关键词突出 // 页面搜索关键词突出 $(function () {...
jQuery实时显示日期、时间 html: &lt;span id=&quot...
jQuery 添加水印 &lt;script src=&quot;../../../.....
中文:Sys.WebForms.PageRequestManagerParserErrorExceptio...
1. 用Response.Write方法 代码如下: Response.Write(&q...
Jquery实现按钮点击遮罩加载,处理完后恢复 思路: 1.点击按...