QQ登录

只需要一步,快速开始

APP扫码登录

只需要一步,快速开始

查看: 2866|回复: 0

[HTML/CSS/JS] 仅含有CSS代码的rate评分组件

[复制链接]

等级头衔

积分成就    金币 : 2861
   泡泡 : 1516
   精华 : 6
   在线时间 : 1327 小时
   最后登录 : 2026-5-3

丰功伟绩

优秀达人突出贡献荣誉管理论坛元老活跃会员

联系方式
发表于 2021-3-15 10:17:04 | 显示全部楼层 |阅读模式
原理如下:
$ 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 { 1.jpg # ^- 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 2.gif 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 3.gif % 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 4.gif
" J; Z: V# N8 u( e鼠标移入预览选中效果
0 D! y& V" ?# i5 K% e
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);
}
      效果如下:+ }6 {1 I4 t; E- c# n3 E9 j
5.gif
# 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
6.gif ' 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 H
display: flex;
flex-flow: row-reverse;
      兄弟元素操作:  d, r# ^& ~* u2 e2 p7 h) z7 C
input:checked ~ input
点击查看演示>>
) X' a- ?& o/ d点击下载源码>>
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|paopaomj.COM ( 渝ICP备18007172号|渝公网安备50010502503914号 )

GMT+8, 2026-5-5 02:08

Powered by paopaomj X3.5 © 2016-2025 sitemap

快速回复 返回顶部 返回列表