jQuery实现的五星点评功能【案例】
更新时间:2019年02月18日 09:06:44 作者:庚中
这篇文章主要介绍了jQuery实现的五星点评功能,结合具体实例形式分析了jQuery事件响应及页面元素属性动态操作实现五星点评功能相关操作技巧,需要的朋友可以参考下
本文实例讲述了jQuery实现的五星点评功能。分享给大家供大家参考,具体如下:
效果图:

需求分析:
1.鼠标移入li标签,当前li标签和之前的li标签全部变为实心;
2.鼠标移开,所有的li标签变为空心;
3.鼠标点击li标签,当前li标签和之前的li标签全部变为实心
jq代码实现过程:
var shiXin="★";
var kongXin='☆'
$('li').on('mouseenter',function ( ) {
//需求1:鼠标移入后,当前的li标签和前面的li标签显示实心,后面的li标签显示空心
$(this).text(shiXin).prevAll().text(shiXin).end().nextAll().text(kongXin);
}).on('mouseleave',function ( ) {
$('li').text(kongXin);
//找到索引的li,给这个li和它前面的li设置实心
$('li[index="dianji"]').text(shiXin).prevAll().text(shiXin);
}).on('click',function ( ) {
//给点击的li添加索引,其余的去除索引
$(this).attr('index','dianji').siblings().removeAttr('index')
})
完整代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>www.jb51.net jQuery五星点评</title>
<style>
*{
margin: 0;
padding: 0;
}
ul {
list-style:none
}
li {
float:left;
cursor: pointer;
color: red;
font-size: 40px;
}
</style>
</head>
<body>
<ul>
<li>☆</li>
<li>☆</li>
<li>☆</li>
<li>☆</li>
<li>☆</li>
</ul>
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<script>
$ ( function () {
/*一:需求分析: 1.鼠标移入li标签,当前li标签和之前的li标签全部变为实心;
2.鼠标移开,所有的li标签变为空心;
3.鼠标点击li标签,当前li标签和之前的li标签全部变为实心
二:思路分析
1.获取元素
2.注册事件
3.事件处理
*/
/* var shiXin='★';
var kongXin='☆';
$ ( "li" ).on ( "mouseenter", function () {
// 1.鼠标移入li标签,当前li标签和之前的li标签全部变为实心,后面的五角星变为空心(这一步必须要,不然往前移会有bug)
$ ( this ).text ( shiXin ).prevAll ().text ( shiXin ).end().nextAll ().text(kongXin)
//end()方法是返回上一个状态的返回值
} ).on ( "mouseleave", function () {
//2.鼠标移开,所有的li标签变为空心;
$('li').text(kongXin);
$ ( 'li[index="dianji"]' ).text(shiXin).prevAll().text(shiXin);
//
} ).on('click',function ( ) {
//3.鼠标点击li标签,当前li标签和之前的li标签全部变为实心
//给点击的li添加索引
$(this).attr('index','dianji').siblings().removeAttr('index');
})*/
//第二遍:
var shiXin="★";
var kongXin='☆'
$('li').on('mouseenter',function ( ) {
//需求1:鼠标移入后,当前的li标签和前面的li标签显示实心,后面的li标签显示空心
$(this).text(shiXin).prevAll().text(shiXin).end().nextAll().text(kongXin);
}).on('mouseleave',function ( ) {
$('li').text(kongXin);
//找到索引的li,给这个li和它前面的li设置实心
$('li[index="dianji"]').text(shiXin).prevAll().text(shiXin);
}).on('click',function ( ) {
//给点击的li添加索引,其余的去除索引
$(this).attr('index','dianji').siblings().removeAttr('index')
})
} )
</script>
</body>
</html>
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery页面元素操作技巧汇总》、《jQuery常见事件用法与技巧总结》、《jQuery常用插件及用法总结》、《jQuery扩展技巧总结》及《jquery选择器用法总结》
希望本文所述对大家jQuery程序设计有所帮助。
相关文章
EasyUI 数据表格datagrid列自适应内容宽度的实现
这篇文章主要介绍了EasyUI 数据表格datagrid列自适应内容宽度的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-07-07
jQuery EasyUI 为Combo,Combobox添加清除值功能的实例
下面小编就为大家带来一篇jQuery EasyUI 为Combo,Combobox添加清除值功能的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-04-04
使用jQuery Mobile框架开发移动端Web App的入门教程
jQuery Mobile是移动端的基于jQuery的Web前端开发框架,移动设备上的浏览器对HTML5的支持普遍较强,因而jQuery Mobile的UI设计主要针对HTML5,下面就来详细看一下使用jQuery Mobile框架开发移动端Web App的入门教程2016-05-05


最新评论