javascript 从 div id 添加/删除类?

标签 javascript css

我有以下 div:

<div id="locker"></div>

我的 Div Id 使用以下 css 样式:

#locker{
          width:20px;
height:20px;
background-repeat: no-repeat;
background-size:15px 15px;
background-position:5px center;
-webkit-border-radius: 20px;
-moz-border-radius: 20px;
border-radius: 20px;
border-style:solid;
border-width:1px;
border-color:#fff;
padding:3px;
position:relative;
text-align: center;
margin:auto;
 filter: invert(75%);
    -webkit-filter: invert(75%);
    background-image: url('../images/padlock.png');


      }

我还有一个类样式:

                  .locker2{ 
background-image: url('../images/key.png');
      }

当用户点击我的另一个 div 时,我正在运行下面的 javascript,我希望我的 Div 'locker' 的背景图像从 #locker 中的背景图像更改为.locker2

下面是我尝试这样做的方式:

<script>
    $('#edit').click(function(){
    $('input').prop('disabled', false);
    $('input').css("background", "transparent");
    $('#locker').removeClass('#locker').addClass("locker2");
    $('#submit').css("display", "block");
});
</script>

但是背景图像没有改变。请有人可以告诉我我要去哪里错了吗?谢谢

最佳答案

locker 是元素的 id 而不是类,因此出于样式目的,将结构更改为类更容易

$('#edit').click(function() {
  $('input').prop('disabled', false);
  $('input').css("background", "transparent");
  $('#locker').removeClass('locker').addClass("locker2");
  $('#submit').css("display", "block");
});
#locker {
  width: 20px;
  height: 20px;
  background-repeat: no-repeat;
  background-size: 15px 15px;
  background-position: 5px center;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  border-radius: 20px;
  border-style: solid;
  border-width: 1px;
  border-color: #fff;
  padding: 3px;
  position: relative;
  text-align: center;
  margin: auto;
  filter: invert(75%);
  -webkit-filter: invert(75%);
}
.locker {
  background-image: url('//placehold.it/32X32/ff0000');
}
.locker2 {
  background-image: url('//placehold.it/32X32/ff00ff');
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<button id="edit">Edit</button>
<div id="locker" class="locker"></div>

关于javascript 从 div id 添加/删除类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31114779/

相关文章:

javascript - slider 在多个 div 中不起作用

html - IE 条件注释不起作用

javascript - Twitter Bootstrap 弹出窗口显示但看起来很奇怪 - Rails

javascript - 获取 DOM 突变的最后一个节点

javascript - 如何从 Paper.js 的图层中销毁特定(而不是删除)对象/路径/子组

javascript - 带序号的 nvd3 散点图

html - 位置 :absolute "background" image Internet Explorer issue

css - 覆盖 CSS 与使用 Modernizer 选择性地加载 CSS(是的,不)

javascript - 使用Javascript功能上传和预览图像在IE8中不起作用

javascript - 粘性页脚 chrome 不适用于动态内容