2015-09-06 113 views
0

任何想法如何做到这一点与CSS的帮助? 第二个(蓝色边框)是带有以下内容的图像:悬停。图像悬停边框

我想到了另一个图像,最后一个带有边框。

enter image description here

+2

看到你的代码可能会有所帮助。 – j08691

+0

可能的重复 - http://stackoverflow.com/questions/8452739/css-inset-borders –

回答

1

边框总是在元素外......没有“插入边界“ 选项。

另一种方法是插入框阴影。

div { 
 
    display: inline-block; 
 
    width: 200px; 
 
    height: 200px; 
 
    background-image: url(http://lorempixel.com/output/food-q-c-200-200-3.jpg); 
 
    border-radius:16px; 
 
    box-shadow: inset 0 0 0 15px rgba(255,255,255,0.5); 
 
    transition:box-shadow 0.5s ease; 
 
} 
 

 
div:hover { 
 
    box-shadow: inset 0 0 0 15px rgba(0,0,155,1); 
 
}
<div> 
 
</div>

编辑:

内半径选项需要另一个元素。在这个例子中,我使用了一个伪元素。

* { 
 
    -webkit-box-sizing: border-box; 
 
    -moz-box-sizing: border-box; 
 
    box-sizing: border-box; 
 
} 
 

 
div { 
 
    display: inline-block; 
 
    width: 200px; 
 
    height: 200px; 
 
    background-image: url(http://lorempixel.com/output/food-q-c-200-200-3.jpg); 
 
    border-radius:16px; 
 
    position: relative; 
 
    overflow: hidden; 
 
} 
 

 
div::after { 
 
    content: ''; 
 
    position: absolute; 
 
    border-radius:16px; 
 
    top:12px; 
 
    left: 12px; 
 
    height: calc(100% - 25px); 
 
    width: calc(100% - 25px); 
 
    z-index: 1; 
 
    background: transparent; 
 
    box-shadow: 0 0 0 32px rgba(255,255,255,0.8); 
 
} 
 

 
div:hover:after { 
 
    box-shadow: 0 0 0 24px rgba(0,0,155,1); 
 
}
<div></div>

+0

谢谢! almoust,但它没有圆角 – SERG

+0

添加了第二个选项。 –

+0

哇!看起来像魔术。非常感谢你。 – SERG

0

用默认颜色设置边框。然后IMG:悬停{} ---

<div> 
<img src="http://dummy-images.com/abstract/dummy-480x270-Bottles.jpg"> 
</div> 

CSS

img{border:10px solid rgba(0,0,0,0.8);border-radius:8px;} 
img:hover{border:10px solid blue;} 

检查Demo