【发布时间】:2015-11-01 07:08:51
【问题描述】:
我正在玩一些 CSS 过渡,并试图解决这个问题。 我想改变文本颜色(从左到右)而不是背景。
这里是代码:(这里是codepen:http://codepen.io/xkurohatox/pen/zGboMz)
HTML:
<a href="#" class="added_to_cart wc-forward" title="View Cart">View Cart</a>
CSS:
a.added_to_cart.wc-forward {
font-size:100px;
color:black;
}
a.added_to_cart.wc-forward {
display: inline-block;
vertical-align: middle;
-webkit-transform: translateZ(0);
transform: translateZ(0);
box-shadow: 0 0 1px rgba(0, 0, 0, 0);
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
-moz-osx-font-smoothing: grayscale;
position: relative;
-webkit-transition-property: color;
transition-property: color;
-webkit-transition-duration: 0.5s;
transition-duration: 0.5s;
}
a.added_to_cart.wc-forward:before {
content: "";
position: absolute;
z-index: -1;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: red;
-webkit-transform: scaleX(0);
transform: scaleX(0);
-webkit-transform-origin: 0 50%;
transform-origin: 0 50%;
-webkit-transition-property: transform;
transition-property: transform;
-webkit-transition-duration: 0.5s;
transition-duration: 0.5s;
-webkit-transition-timing-function: ease-out;
transition-timing-function: ease-out;
}
a.added_to_cart.wc-forward:hover, a.added_to_cart.wc-forward:focus, a.added_to_cart.wc-forward:active {
color: white;
}
a.added_to_cart.wc-forward:hover:before, a.added_to_cart.wc-forward:focus:before, a.added_to_cart.wc-forward:active:before {
-webkit-transform: scaleX(1);
transform: scaleX(1);
-webkit-transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
}
我已经尝试了显而易见的方法,例如将背景颜色更改为颜色并使用 translateZ。我认为我以前从未见过 css 字体颜色转换,所以我很想看看这里是否有人有足够的天赋来想出一个。
从这里获取基本代码:https://github.com/IanLunn/Hover
提前谢谢你 xx :)
【问题讨论】:
标签: html css css-transitions css-animations