原理如下:8 P4 |2 C" @* y
- 去找个好看的iconfont,[Iconfont-阿里巴巴矢量图标库;
- 借用5个radio单选框,把默认样式都去掉,显示默认的星星;
- 用checked伪类监听用户选中,由默认的星星变成高亮的星星;
- 然后配合~兄弟操作符把当前选中的所有兄弟元素都一起高亮;
- 把5个radio单选框反向排列;
! f+ B `$ r- S. H }. ^ / L/ N ?, e5 `/ l4 P
基本布局:
) d, I2 O4 o! @7 o 这是我事先生成好的iconfont:
" {1 W) {: u' A: f1 l6 Z<link rel="stylesheet" href="//at.alicdn.com/t/font_1356455_c5d3d3ohlbq.css"> 一个很简洁的布局:+ A. o# n4 w1 A# F( s' k u; g
<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> 先把默认的星星显示出来:
; I8 v$ N+ }6 I/* 去掉默认样式 */
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;
} 效果如下:; O# V5 h1 @' ^) @$ t; c6 t
6 V: E8 F \- V+ W/ x实现选中单个星星
! _! G0 F7 K) Z A$ x7 X* A/* 实现选中单个星星 */
/* 高亮的星星 */
input[name="rate"]:checked::after {
content: "\e73c";
color: var(--main);
} 效果如下:
8 P- u v( p* e) V# \: `
* F4 O$ y, I5 q1 j5 g6 Z1 a
实现连同兄弟元素一起高亮
, H& @2 a1 [& I7 L/* 实现选中单个星星 */
/* 高亮的星星 */
input[name="rate"]:checked::after,
input[name="rate"]:checked~input[name="rate"]::after {
/*实现连同兄弟元素一起高亮*/
content: "\e73c";
color: var(--main);
} 效果如下:) d% q& v6 p, ~$ X) h# |
$ K+ D" Y2 @3 V" ~
把input反向排列
" k( c9 X$ r& I b4 `& w4 `6 ?/ U.rate-content {
display: flex;
flex-flow: row-reverse;
} 效果如下:
; T- b1 K* `; C1 e: g6 v% |
% H) w# k. ?% J( e, W/ C鼠标移入预览选中效果
, P$ }! N, E; B0 R; U4 n8 o- Tinput[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 H9 A% o$ F+ I# v& J2 V) a$ l! x/ [
' i/ x- C0 e) s
加入放大动画
; R7 \: A' W' U0 A6 C" Jinput[name="rate"] {
transition: transform .2s ease;
}
input[name="rate"]:checked,
input[name="rate"]:hover {
transform: scale(1.2);
} 效果如下:
6 g* E# s4 _2 O! R
# @$ ~5 N; N* c总结:( ?* ^0 a3 ?" |9 O4 E! i! B
核心代码其实就是这两段,其他都是可选的。
3 R$ f* |$ N% o# t! W4 F+ b9 X! j$ u 元素反向排列:; A1 j* X1 B. ]+ \4 p0 I
8 y) l. z- O$ w t( N) j+ Qdisplay: flex;
flex-flow: row-reverse; 兄弟元素操作:3 [" @+ N. e, X: `3 _' D
input:checked ~ input 点击查看演示>>
`2 a# D% J0 ]! [8 `/ s点击下载源码>> |