原理如下:
$ z# u0 G. T2 S4 z8 n, b- t- o- 去找个好看的iconfont,[Iconfont-阿里巴巴矢量图标库;
- 借用5个radio单选框,把默认样式都去掉,显示默认的星星;
- 用checked伪类监听用户选中,由默认的星星变成高亮的星星;
- 然后配合~兄弟操作符把当前选中的所有兄弟元素都一起高亮;
- 把5个radio单选框反向排列;5 b$ R J; @) T2 N- D
' ]! S: v1 ~6 z# |4 t( p$ r
基本布局:
6 J& q( \% c3 E3 K, | 这是我事先生成好的iconfont:
5 c5 d( W- k" d1 W7 E+ V<link rel="stylesheet" href="//at.alicdn.com/t/font_1356455_c5d3d3ohlbq.css"> 一个很简洁的布局:; z/ D! c8 p9 B# K6 F: c& M& H# {
<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> 先把默认的星星显示出来:
' O D* D3 q1 U- L1 D/* 去掉默认样式 */
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;
} 效果如下:
5 ^+ D/ R5 f5 y- {* B+ a3 {
# ^- T2 J* E9 Y: \
实现选中单个星星
; c2 ~# n4 F2 R/* 实现选中单个星星 */
/* 高亮的星星 */
input[name="rate"]:checked::after {
content: "\e73c";
color: var(--main);
} 效果如下:
- b, |) `7 P' g( J N" s9 |& p
0 g1 M [$ j0 N# J
实现连同兄弟元素一起高亮2 b7 n/ b2 O8 K: ^
/* 实现选中单个星星 */
/* 高亮的星星 */
input[name="rate"]:checked::after,
input[name="rate"]:checked~input[name="rate"]::after {
/*实现连同兄弟元素一起高亮*/
content: "\e73c";
color: var(--main);
} 效果如下:
* K9 m1 l, f( p) W( j9 |- P
% Y0 Q5 j+ q7 @ F/ o2 F4 N
把input反向排列
5 F2 ]" w$ Q. h$ }& @. f.rate-content {
display: flex;
flex-flow: row-reverse;
} 效果如下:
$ K3 V1 V- C+ [7 @8 ?7 y
" J; Z: V# N8 u( e鼠标移入预览选中效果
0 D! y& V" ?# i5 K% einput[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);
} 效果如下:+ }6 {1 I4 t; E- c# n3 E9 j
# A. s' y8 m# U% r4 i m8 s/ a加入放大动画3 b; o' X: V# N# q0 w& R! ~& [$ p
input[name="rate"] {
transition: transform .2s ease;
}
input[name="rate"]:checked,
input[name="rate"]:hover {
transform: scale(1.2);
} 效果如下:6 Y% q3 o' S; `7 \ I
' d9 ~; j6 R4 { ]6 j
总结:
+ S1 N0 I+ Z8 y3 b& G 核心代码其实就是这两段,其他都是可选的。! N1 y* j% J3 q0 n! M% V
元素反向排列:
. d& x9 o) W D9 f
5 J0 M1 }. Z. R3 {0 Hdisplay: flex;
flex-flow: row-reverse; 兄弟元素操作: d, r# ^& ~* u2 e2 p7 h) z7 C
input:checked ~ input 点击查看演示>>
) X' a- ?& o/ d点击下载源码>> |