Как создать анимированную границу при наведении
Я хочу создать эффект при наведении как на этом сайте:
http://themes.creiden.com/circleflip/blog-with-sidebar/
просто наведите курсор на ссылку "больше".
http://joxi.ru/uXHGU_3JTJBkDpt35Iw
поэтому я попытался сделать что-то вроде этого, но у меня есть только это вариант
код:
HTML-код
<a href="#">Click the link</a>
в CSS
body{
padding: 100px;
background: #f6f6f6;
}
a{
display: block;
width: 200px;
position: relative;
background: #fff;
height: 40px;
font: 14px/40px Tahoma;
color: #39adf0;
text-decoration: none;
-webkit-transition: 0.2s;
margin: auto;
text-align: center;
position: relative;
}
a:after{
content: '';
position: absolute;
top: 0;
left: 0;
width: 0;
height: 1px;
background: #39adf0;
-webkit-transition: 0.2s;
-moz-transition: 0.2s;
-ms-transition: 0.2s;
-o-transition: 0.2s;
transition: 0.2s;
}
a:before{
content: '';
position: absolute;
top: 0;
right: 0;
width: 1px;
height: 0;
background: #39adf0;
-webkit-transition: 0.2s;
-moz-transition: 0.2s;
-ms-transition: 0.2s;
-o-transition: 0.2s;
transition: 0.2s;
}
a:hover:after{
width: 100%;
}
a:hover:before{
content: '';
position: absolute;
top: 0;
right: 0;
width: 1px;
height: 100%;
background: #39adf0;
-webkit-transition: 0.2s;
-moz-transition: 0.2s;
-ms-transition: 0.2s;
-o-transition: 0.2s;
transition: 0.2s;
}
но в Примере (на сайте) инсульт появляется в порядке и во все стороны... Как я могу это сделать? Только CSS3? Может быть, с помощью jQuery?
4 ответов
Вы можете использовать этот код, я скопировал с вашего образца веб-сайта.
HTML-код:
<a href="#">
<span class="text">Click the link</span>
<span class="btnBefore"></span>
<span class="btnAfter"></span>
</a>
css: ля { поплавок: слева; границы-радиус: 5 пикселей; маржи-топ: 10 ПКС; положение: относительное; z-индекс: 1; переполнение: скрыто; мин-ширина: 47px; дисплей: таблица; обивка: 6px 9рх; граница: нет; - webkit-переход: все 0.5 s простота; - moz-переход: все 0.5 s легкость; - ms-переход: все 0.5 s простота; - o-переход: все 0.5 s простота; переход: вся легкость 0.5 s; текст-выровняйте: центр; цвет: #fff; фон-цвет: #E32831; текст-отделка: нет; } парение { фон-цвет: #f1f1f1 !важный; }
span {
position: relative;
z-index: 1;
line-height: 23px;
transition: 0.3s ease;
-webkit-transition: 0.3s ease;
-moz-transition: 0.3s ease;
-o-transition: 0.3s ease;
-ms-transition: 0.3s ease;
}
a:hover span {
color: #5a5a5a;
}
.btnBefore, .btnAfter {
content: '';
position: absolute;
height: 0;
width: 0;
border: solid #e32831;
border-width: 0;
border-radius: 0;
transition: 0;
-webkit-transition: 0;
-moz-transition: 0;
-o-transition: 0;
-ms-transition: 0;
box-sizing: border-box;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
border-color: #E32831;
border-radius: 5px;
}
a .btnBefore {
right: 0;
bottom: 0;
}
a .btnAfter {
left: 0;
top: 0;
}
a:hover .btnBefore {
border-width: 0 0 1px 1px;
}
a:hover .btnAfter {
border-width: 1px 1px 0 0;
}
a:hover .btnAfter, a:hover .btnBefore {
height: 100%;
width: 100%;
transition: width 0.5s ease, height 0.5s ease 0.5s, border-top-right-radius 0.1s ease 0.4s, border-bottom-left-radius 0.1s ease 0.4s, border-bottom-right-radius 0.1s ease 0.9s, border-top-left-radius 0.1s ease 0.9s;
-webkit-transition: width 0.5s ease, height 0.5s ease 0.5s, border-top-right-radius 0.1s ease 0.4s, border-bottom-left-radius 0.1s ease 0.4s, border-bottom-right-radius 0.1s ease 0.9s, border-top-left-radius 0.1s ease 0.9s;
-moz-transition: width 0.5s ease, height 0.5s ease 0.5s, border-top-right-radius 0.1s ease 0.4s, border-bottom-left-radius 0.1s ease 0.4s, border-bottom-right-radius 0.1s ease 0.9s, border-top-left-radius 0.1s ease 0.9s;
-o-transition: width 0.5s ease, height 0.5s ease 0.5s, border-top-right-radius 0.1s ease 0.4s, border-bottom-left-radius 0.1s ease 0.4s, border-bottom-right-radius 0.1s ease 0.9s, border-top-left-radius 0.1s ease 0.9s;
-ms-transition: width 0.5s ease, height 0.5s ease 0.5s, border-top-right-radius 0.1s ease 0.4s, border-bottom-left-radius 0.1s ease 0.4s, border-bottom-right-radius 0.1s ease 0.9s, border-top-left-radius 0.1s ease 0.9s;
}
et voila!
вы действительно можете приблизиться, используя чистый CSS, используя псевдоэлементы и ключевые кадры анимации. Преимущества уменьшаются DOM беспорядок, нет JS и строгое разделение проблем (придерживаясь CSS для укладки).
обратите внимание, что приведенный ниже пример работает в Chrome, добавьте / удалите -webkit-
префикс поставщика в зависимости от других браузеров (пример для Chrome, FF).
HTML-код
<a href='#'>hover!</a>
в CSS
a {
background:#E32831;
padding:10px 15px;
display:inline-block;
box-sizing:border-box;
position:relative;
overflow:hidden;
color:white;
transition:all 200ms ease-in;
border-radius:5px;
font-family:arial;
text-decoration:none;
font-size:12px;
}
a:before, a:after {
display:block;
width:100%;
content:'';
box-sizing:border-box;
position:absolute;
height:0px;
border-radius:5px;
}
a:before {
border-top:1px solid red;
border-right:1px solid red;
left:-100%;
top:0;
height:0px;
}
a:after {
border-bottom:1px solid red;
border-left:1px solid red;
left:100%;
bottom:0;
height:0px;
}
@-webkit-keyframes left-up {
0% {
left:100%;
height:0;
}
50% {
left:0;
height:0;
}
100% {
height:100%;
left:0;
}
}
@-webkit-keyframes right-dn {
0% {
left:-100%;
height:0;
}
50% {
left:0;
height:0;
}
100% {
height:100%;
left:0;
}
}
a:hover {
background:lightgrey;
color:#808080;
}
a:hover:after, a:hover:before {
-webkit-animation-duration:900ms;
-webkit-animation-iteration-count: 1;
-webkit-animation-timing-function: ease-in-out;
-webkit-animation-fill-mode: forwards
}
a:hover:after {
-webkit-animation-name:left-up;
}
a:hover:before {
-webkit-animation-name:right-dn;
}
используя jquery, я смог воссоздать поведение почти точно:JSFiddle
$('a').append('<div class="borders" id="TL"></div><div class="borders" id="BL"></div><div class="borders" id="TR"></div><div class="borders" id="BR"></div>');
$('a').mouseover(function(){
$(this).stop().find('#TL, #BR').css("display","block").animate({width:"100%"},"fast", function(){
$(this).siblings('#TR, #BL').css("display","block").animate({height:"100%"},"fast"); })}
).mouseout(function(){
$(this).find('#BL, #TR').animate({height:"0px"},"fast", function(){
$(this).siblings('#BR, #TL').animate({width:"0px"},"fast")}
);
});
.borders { display: none; width: 1px; height: 1px; background: red; position: absolute; }
#TL { top: 0; left: 0; }
#BL { bottom: 0; left: 0; }
#TR { top: 0; right: 0; }
#BR { bottom: 0; right: 0; }
вы можете использовать псевдоэлементы CSS со свойствами перехода. Если вы хотите больше на границе анимации, используйте SVG анимации. Я рекомендую вам взглянуть на SVG-анимации. ниже приведена хорошая статья для анимации SVG на границе и демо чистой анимации css.
<pre>http://jsfiddle.net/Mostwanted_cJ/F8uZE/<code>