我这个是在前一篇文章所介绍的js脚本基础上做的修改。(请先看前面一篇《星级评分效果 -js实现 》)
由于把前面的脚本引入项目里,发现当鼠标移到星星图片上获取到的OY值并不在1到19之间,所以导致该功能不起作用。后来通过调试测试发现在IE中当鼠标移动到星星图片上通过event获取到的offsetY的值无论页面向上向下滑动多少其值永远在1到19之间。
所以修改了程序脚本,原来OY修改为event.offsetY,,有人会问了在firefox中没有offsetY这个属性,其实在firefox中的layerY与IE中的offsetY获取到的值是一样的。
还有一点发现通过传过去的e在IE中运行并不存在,所以添加了一个判断若e不存在则获取window.event。
主要代码如下:
JS代码:
HEML代码:
默认值设定为80分,其主要通过<li>中背景图片的宽度来达到所展示出来的星级评分效果。
公式为:Math.round(分数/84*100)
如:Math.round(80/84*100)=67
Css样式则没太多变化只是引用图片的路径做了适当修改,样式代码可见前一篇文章。