jquery - 实现评级和 jquery 的简单问题

标签 jquery html css jquery-selectors

我这里有一个非常简单的问题,但由于我对 jquery 知之甚少,所以无法解决这个问题

我正在使用这段代码来实现评分功能

http://www.dotnetcurry.com/ShowArticle.aspx?ID=440

一切正常,但后来我注意到一旦有人点击任何星星,它就无法更改评分。

这是代码

建立星阵

<p>
    <img src="Images/EmptyStar.png" alt="Star Rating" align="middle" id="1" />
    <img src="Images/EmptyStar.png" alt="Star Rating" align="middle" id="2" />
    <img src="Images/EmptyStar.png" alt="Star Rating" align="middle" id="3" />
    <img src="Images/EmptyStar.png" alt="Star Rating" align="middle" id="4" />
    <img src="Images/EmptyStar.png" alt="Star Rating" align="middle" id="5" />
</p>

JS 部分

$("img").mouseover(function() {
    giveRating($(this), "FilledStar.png");
    $(this).css("cursor", "pointer");
});

$("img").mouseout(function() {
    giveRating($(this), "EmptyStar.png");
});

//--------

function giveRating(img, image) {            
    img.attr("src", "Images/" + image).prevAll("img").attr("src", "Images/" + image);
}

现在,一旦任何人点击任何星星,点击事件就会生效并按如下方式解除绑定(bind):

$("img).click(function () {
    $(img).unbind("mouseout mouseover click");
});

我在看,即使有人点击了任何开始,他也应该能够再次更改它,选择更高或更低的评级

如果有人能指导我这个简单的事情,我将不胜感激

提前感谢您的时间和努力

最佳答案

首先删除这个:

$(img).unbind("mouseout mouseover click");

此外,您还必须存储评级并在搬出后恢复它...

function giveRating(img, image) {            
    img.attr("src", "Images/" + image).prevAll("img").attr("src", "Images/" + image);
    img.parent().get(0).rating = img;
}

...

抱歉,我不太容易完成这个。也许其他人会?

或者看看http://www.fyneworks.com/jquery/star-rating/

为此有许多现成的解决方案。

关于jquery - 实现评级和 jquery 的简单问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12499042/

相关文章:

jquery - 如何隐藏和防止在页面加载期间显示网页内容并改为显示动画 gif 图像

javascript - 多维数组。推送然后加入

javascript - 为什么一些专业的网页设计师使用绝对路径而不是相对路径(例如 CSS、Javascript、图像等)?

javascript - PHP触发从iframe到其他页面的提交

javascript - CSS 向下滚动动画处理轨迹线

html - net::ERR_INSECURE_RESPONSE 与 CDN

javascript - 我在 javascript 中执行 setTimeout 加载符号?

javascript - 如果脚本已经在浏览器缓存中,浏览器还会延迟加载脚本吗?

javascript - 我的 Jquery/Javascript 无法连接! - 在 HTML 中工作 - 编程新手

javascript - 滑动到网站中的不同页面