原理如下:
* X0 @8 s7 W$ o$ W# S. Q- 去找个好看的iconfont,[Iconfont-阿里巴巴矢量图标库;
- 借用5个radio单选框,把默认样式都去掉,显示默认的星星;
- 用checked伪类监听用户选中,由默认的星星变成高亮的星星;
- 然后配合~兄弟操作符把当前选中的所有兄弟元素都一起高亮;
- 把5个radio单选框反向排列;( X+ {$ r/ f" t0 e* G
0 P) [; @ w m; F' A+ L5 _基本布局:% j) h0 b9 e6 X4 J3 r
这是我事先生成好的iconfont:# {+ y& J0 l' I
<link rel="stylesheet" href="//at.alicdn.com/t/font_1356455_c5d3d3ohlbq.css"> 一个很简洁的布局: {5 f% y/ b E: R, c
<div class="rate-content">
<input type="radio" name="rate">
<input type="radio" name="rate">
<input type="radio" name="rate">
<input type="radio" name="rate">
<input type="radio" name="rate">
</div> 先把默认的星星显示出来:9 s' j7 N# q7 m2 |9 N$ @. V
/* 去掉默认样式 */
input {
-webkit-appearance: none;
border: none;
outline: none;
cursor: pointer;
}
:root {
/*高亮颜色*/
--main: #ffa822;
/*默认颜色*/
--basic: #999;
}
.rate-contentinput[name="rate"] {
font-family: "iconfont";
/*之前引入的iconfont字体*/
font-size: 30px;
padding-right: 10px;
}
.rate-contentinput[name="rate"]::after {
content: "\e645";
color: var(--basic);
/*加点颜色过渡效果*/
transition: color .4s ease;
} 效果如下:3 x# \! _( i8 _/ @9 L' u3 N
* ^$ V, h* ~! F. x实现选中单个星星4 v% q5 W9 h. D7 H9 y
/* 实现选中单个星星 */
/* 高亮的星星 */
input[name="rate"]:checked::after {
content: "\e73c";
color: var(--main);
} 效果如下:
9 ^% z! d: m7 R, X, @/ W9 a$ k4 u: q
0 S0 n9 a! K7 s) N! ?. b" D+ E) W& D
实现连同兄弟元素一起高亮
/ l8 G, f- Y2 v& b( t8 d/* 实现选中单个星星 */
/* 高亮的星星 */
input[name="rate"]:checked::after,
input[name="rate"]:checked~input[name="rate"]::after {
/*实现连同兄弟元素一起高亮*/
content: "\e73c";
color: var(--main);
} 效果如下:
/ Q: v: k. E5 `% W* c
' o3 J y ~* V把input反向排列4 k3 ?1 n( G% ~) \0 C
.rate-content {
display: flex;
flex-flow: row-reverse;
} 效果如下: Z( S. t, A: L
8 h J5 y- W6 b鼠标移入预览选中效果
7 a& S) Q. X9 _' u- kinput[name="rate"]:checked,
input[name="rate"]:hover::after {
content: "\e73c";
color: var(--main);
}
/* 兄弟元素一起高亮 */
input[name="rate"]:hover~input[name="rate"]::after {
content: "\e73c";
color: var(--main);
} 效果如下:
2 c+ f, s7 }: R
1 M/ t) ]. j+ L- C) {加入放大动画
" O) ^* ?: I; {& ginput[name="rate"] {
transition: transform .2s ease;
}
input[name="rate"]:checked,
input[name="rate"]:hover {
transform: scale(1.2);
} 效果如下:
$ T _0 |3 j; F0 K! u; H
6 C" U4 p% @) F8 _2 A
总结:
+ e/ G5 H4 f3 m0 |9 v 核心代码其实就是这两段,其他都是可选的。
$ S' l+ o6 i& ` 元素反向排列:
$ W V. P/ h$ l: w. N' m8 R! L e4 M! _2 M7 u; r( C1 C: I" _+ X" P) t. `
display: flex;
flex-flow: row-reverse; 兄弟元素操作:
7 p5 j7 F5 B5 ]8 O, ^: v7 K/ V0 linput:checked ~ input 点击查看演示>>5 f/ a4 I, d* x. x; z0 ^# I- d+ e. `: k
点击下载源码>> |