0

我想知道是否有办法延迟从“覆盖”到“包含”的背景大小的悬停效果?我已经看到过渡延迟适用于背景颜色和其他属性,但不适用于背景大小。任何帮助将不胜感激。谢谢!

div{
    display:inline-block;
    width: 100px;
    height: 100px;
    padding:5px;
    margin:10px;
    border:1px solid #ccc;
    background-image: url("http://i.stack.imgur.com/2OrtT.jpg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    transition: 0s background-size;
    transition-delay:1s;
}
div:hover{
    background-size: contain;
    background-color:red;
}

http://jsfiddle.net/rtku7sqk/

更新 也许我应该澄清一下我想延迟悬停效果发生但不延长动画的持续时间。

与此类似... http://dabblet.com/gist/1498443


最近更新

我想出了一种通过混合使用 CSS 和 javascript 来解决这个问题的方法。

这种方式“背景大小”与“包含”和“覆盖”一起使用

$("#tmp").hover(function() {

    /* Mouse enter */
    var thisone = $(this);
    window.mytimeout = setTimeout(function() {
        thisone.addClass("mouseon");
    }, 1000);

}, function() {

    /* Mouse leave */
    clearTimeout(window.mytimeout);
    $(this).removeClass("mouseon");
});

http://jsfiddle.net/rtku7sqk/5/

4

3 回答 3

1

因此,您的 CSS 只有一件小事,否则它将完全按照您的预期工作。

您不能从非数值转换

containcoverforbackground-size不能转换。由于它们是非数字的,因此您无法对它们进行 CSS 计算。

如果您将其更改为如下示例中的数值,它将完全按照您的预期发生:

小提琴说明这个例子

以下是对 CSS 的更改:

div{
    display:inline-block;
    width: 100px;
    height: 100px;
    padding:5px;
    margin:10px;
    border:1px solid #ccc;
    background-image: url("http://i.stack.imgur.com/2OrtT.jpg");
    background-size: 100%; /* NOT `cover` anymore */
    background-repeat: no-repeat;
    background-position: 50% 50%;
    transition: 0s background-size;
    transition-delay: 1s;
}
div:hover{
    background-size: 20%; /* NOT `contain` anymore */
    background-color:red;
}
于 2014-11-26T18:29:57.007 回答
0

试试 jQuery 动画功能怎么样?无需付出极大的努力,我认为这是您解决问题的良好开端。当然,您可以根据需要进行修改。

注意:我了解您要求 CSS,但在这种情况下,JQuery 将是您最好的选择。但是,如果您只请求 CSS,请忽略此响应。但我发布它是因为未来的访问者可能能够使用此方法并且不受您的限制。干杯!

$( "div ").hover(function() {
    $( "img" ).animate({
      width: "100%",
    }, 1500 );
});

演示

于 2014-11-26T17:54:02.350 回答
0

你可以这样做:


演示


如果您想进行过渡,则应使用带有 px 的背景位置,例如:

div{
   background-position: 0px 0px;
}
div:hover{
   background-position: center center;
}
于 2014-11-26T21:25:50.690 回答