<div> <em>8.0</em> <span> <span></span> <ul> <li><a href="javascript:void(0)" data-name="很差">1</a></li> <li><a href="javascript:void(0)" data-name="较差">2</a></li> <li><a href="javascript:void(0)" data-name="一般">3</a></li> <li><a href="javascript:void(0)" data-name="较好">4</a></li> <li><a href="javascript:void(0)" data-name="很好">5</a></li> </ul> </span> <div></div> </div>
简单描述下原理:主要是多层背景的覆盖关系
首先是结构:.star下面包含了两层,一层是ystar,一层是ul。
4.1、实现4个星星的评分效果
外层.star定宽,背景图为空心灰色的星星。
里面.ystar代表点亮的星星,它的背景是实心的黄色星星,如果有4颗亮星,就设置.ystar的宽度为80%。2颗为40%。
4.2、实现鼠标hover上去星星点亮的效果
主要是通过css控制。关键是通过:hover实现的。
ul:hover时加上了空心灰色的星星背景图。
a:hover时,宽度变成前几个星星的宽度。
这样在hover时,其实有4层背景,比如第二个星星hover时,从下到上依次是
.star 暗星100%宽度.ystar 亮星 80宽度ul 暗星100%宽度.two-stars 40%宽度
4.3、鼠标hover显示tip
通过js获取a的data-name实现。
以上所述是小编给大家介绍的JS实现星星评分功能实例代码(两种方法)的详细内容,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章: