原理如下:
7 m7 t+ n5 ?. M [% O4 Y$ b+ U' L0 M- 去找个好看的iconfont,[Iconfont-阿里巴巴矢量图标库;
- 借用5个radio单选框,把默认样式都去掉,显示默认的星星;
- 用checked伪类监听用户选中,由默认的星星变成高亮的星星;
- 然后配合~兄弟操作符把当前选中的所有兄弟元素都一起高亮;
- 把5个radio单选框反向排列;$ Z4 s( H7 X. n- r
' ^ }6 f- T8 F6 V$ B' N( l4 h
基本布局:
" H3 L. ?6 {; E0 U1 Z, h 这是我事先生成好的iconfont:
^0 d+ j: ?4 {: z% s6 ]/ b<link rel="stylesheet" href="//at.alicdn.com/t/font_1356455_c5d3d3ohlbq.css"> 一个很简洁的布局:9 j- h+ n3 b! R- V
<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> 先把默认的星星显示出来:. A# C. Q \% P6 b6 i4 o# R
/* 去掉默认样式 */
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;
} 效果如下:) v4 C7 ?% }# X0 \6 Z
& R; d8 |7 w; M/ b
实现选中单个星星
/ D* @" \9 j0 }9 g/* 实现选中单个星星 */
/* 高亮的星星 */
input[name="rate"]:checked::after {
content: "\e73c";
color: var(--main);
} 效果如下:: g4 n3 j# T: M0 L1 {) Q
* r3 U' `: Y0 f: p# Y
实现连同兄弟元素一起高亮2 t, E. [4 Q! Z$ K
/* 实现选中单个星星 */
/* 高亮的星星 */
input[name="rate"]:checked::after,
input[name="rate"]:checked~input[name="rate"]::after {
/*实现连同兄弟元素一起高亮*/
content: "\e73c";
color: var(--main);
} 效果如下: z( [* h* Q* M5 b/ g
6 D/ X# o. _7 p! Y$ G! W把input反向排列
0 S3 K" W& n) V) E1 @! I+ j" W' [.rate-content {
display: flex;
flex-flow: row-reverse;
} 效果如下: Y3 p/ R( b9 S4 d& I/ p
% c3 |* k: Q% u# |
鼠标移入预览选中效果% a! k0 {& U( R8 `9 A' @! q& L
input[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);
} 效果如下:7 z' U2 F/ o* @- N# r+ U, m
9 i5 ] u, ]: P' U$ N! D' u/ a
加入放大动画4 f5 l% l! W, J( I# W4 v2 @3 Q
input[name="rate"] {
transition: transform .2s ease;
}
input[name="rate"]:checked,
input[name="rate"]:hover {
transform: scale(1.2);
} 效果如下:
# \0 g5 W3 X4 M- j; j5 n) \
/ x4 [2 R f2 f& _8 |总结:
9 ]4 C* o0 W K; P0 ? 核心代码其实就是这两段,其他都是可选的。
: G5 |% t! ]# S 元素反向排列:
! T$ k3 a$ s& m) X- G
0 ?( O% Z) q+ S% @: |/ y( T& hdisplay: flex;
flex-flow: row-reverse; 兄弟元素操作:5 M* o1 g0 P% x u
input:checked ~ input 点击查看演示>>
+ M/ G) R# N/ e, K, G; z点击下载源码>> |