首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Jquery移除css类名问题

Jquery移除css类名问题
EN

Stack Overflow用户
提问于 2016-01-10 05:04:21
回答 1查看 38关注 0票数 0

每次我选择一个评级,然后清除它并悬停在收视率之上,我刚刚清除的前一个评等再次显示,就好像我再次选择了它一样。我怎么才能阻止这一切的发生。例如,让我点击3星级评级,然后单击清除,然后我悬停在5星级评级,并把我的鼠标从收视率,三星级评级将突出显示,我选择它。我怎么才能阻止这一切。

下面是指向JsFiddle https://jsfiddle.net/a2t0syzh/的链接

HTML

代码语言:javascript
复制
<form method="" action="" id="rating-form">
  <fieldset>
    <ol>
      <li>
        <ul class="rating-pick notrated">
          <li id="rate-1" data-desc="Bad">
            <label for="rating-1">
              <input type="radio" value="1" name="rating" id="rating-1" />1 star</label>
          </li>
          <li id="rate-2" data-desc="Good">
            <label for="rating-2">
              <input type="radio" value="2" name="rating" id="rating-2" />2 stars</label>
          </li>
          <li id="rate-3" data-desc="Great">
            <label for="rating-3">
              <input type="radio" value="3" name="rating" id="rating-3" />3 stars</label>
          </li>
          <li id="rate-4" data-desc="Better">
            <label for="rating-4">
              <input type="radio" value="4" name="rating" id="rating-4" />4 stars</label>
          </li>
          <li id="rate-5" data-desc="Best">
            <label for="rating-5">
              <input type="radio" value="5" name="rating" id="rating-5" />5 stars</label>
          </li>
        </ul>
        <a class="clear" title="" href="#">Clear</a>
        <div class="rate" data-desc="Rate this product">Rate this product</div>
      </li>
    </ol>
  </fieldset>
</form>

Jquery

代码语言:javascript
复制
$(document).ready(function(){
    var rating = 'notrated';
    $('.rating-pick li')
        .on('mouseenter touchstart', function(){
            $(this).parent().removeClass($(this).parent().attr('class').split(' ')[1]);
            var classSuffix = $(this).attr('id').split('-')[1];
            $('.rating-pick').addClass('rating-' + classSuffix);
            $('.rate').text($(this).data('desc'));
        })
        .on('mouseleave touchend', function(){
            var classSuffix = $(this).attr('id').split('-')[1];
            $('.rate').text($('.rate').attr('data-desc'));
            $('.rating-pick').attr('class', '').addClass('rating-pick ' + rating)
        })
        .on('change click', function(e){
            e.preventDefault();
            e.stopPropagation();
            $('.rate').attr('data-desc', $(this).attr('data-desc'));
            rating = 'rating-' + $(this).attr('id').split('-')[1];
            $('.rating-pick').removeClass('notrated').addClass(rating);
            $(this).find('input').prop('checked', true);
        });
});

$(document).ready(function(){
    $('.clear').on('change click', function(e){
        e.preventDefault();
        e.stopPropagation();
        $('#rating-form').find('input:checked').prop('checked', false);
        $('#rating-form').find('ul').removeClass().addClass('rating-pick notrated');
    });
});

CSS

代码语言:javascript
复制
* {
  margin: 0;
  padding: 0;
  border: 0;
}

#rating-form ol li {
  list-style: none;
  width: 100%;
  float: left;
}

#rating-form label {
  display: inline-block;
  margin-bottom: 0.2em;
  font-weight: bold;
  width: 100%;
}

.rate {
  float: left;
  width: 100%;
  margin: -1.4em 0 1.8em 0;
}

.rating-pick {
  width: 150px;
  height: 30px;
  float: left;
  margin-bottom: 1.8em;
}

.notrated {
  background-image: url('http://s8.postimg.org/xgfpw2679/stars.png');
  background-repeat: repeat-x;
  background-position: 0px 0px;
}

.rating-1 {
  background-image: url('http://s8.postimg.org/xgfpw2679/stars.png');
  background-repeat: repeat-x;
  background-position: 0px -60px;
}

.rating-2 {
  background-image: url('http://s8.postimg.org/xgfpw2679/stars.png');
  background-repeat: repeat-x;
  background-position: 0px -120px;
}

.rating-3 {
  background-image: url('http://s8.postimg.org/xgfpw2679/stars.png');
  background-repeat: repeat-x;
  background-position: 0px -180px;
}

.rating-4 {
  background-image: url('http://s8.postimg.org/xgfpw2679/stars.png');
  background-repeat: repeat-x;
  background-position: 0px -240px;
}

.rating-5 {
  background-image: url('http://s8.postimg.org/xgfpw2679/stars.png');
  background-repeat: repeat-x;
  background-position: 0px -300px;
}

.rating-pick input[type="radio"],
.rating-pick label {
  height: 0 !important;
  display: none !important;
}

.rating-pick li {
  float: left !important;
  width: 30px !important;
  height: 30px !important;
  display: block !important;
  list-style-type: none !important;
  cursor: pointer !important;
}

.clear{
    display: inline-block;
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-01-10 05:19:25

您正在使用以下行设置评等:

代码语言:javascript
复制
$('.rating-pick').attr('class', '').addClass('rating-pick ' + rating)

请注意,rating变量是在此$(document).ready处理程序中定义的,并且在单击clear时不会重置。因此,当鼠标退出ul时,它会将评级重置为存储在rating变量中的任何内容。

只需做以下修改:

代码语言:javascript
复制
var rating = 'notrated'; //move rating out of other functions

$(document).ready(function(){
    $('.rating-pick li')

然后在明确单击时将评级重置为“notrated”:

代码语言:javascript
复制
$('.clear').on('change click', function(e){
    e.preventDefault();
    e.stopPropagation();
    $('#rating-form').find('input:checked').prop('checked', false);
    $('#rating-form').find('ul').removeClass().addClass('rating-pick notrated');
   rating='notrated';
});

您的小提琴更新了。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34702265

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档