删除克隆元素的数据属性

时间:2018-10-25 14:53:57

标签: javascript jquery

我正在尝试做一个非常简单的事情(看起来):克隆已经存在html元素,修改它的属性并追加到页面上。而且它不起作用,我也不知道为什么。

这是一个简单的演示:                 

Hello World

      换颜色     

// js
var banner = $("#banner-message")
var button = $("button")

// handle click and add class
button.on("click", function(){
  var row = $('#banner-message').find('.test:first').clone(true);
  row.removeData('event-num');
  //row.data('event-num', 500);
  $('#banner-message').find('.test:last').after(row);
})

这是一个jsfiddle演示:https://jsfiddle.net/jn1wm9da/

它既不会删除也不会覆盖(实际上我想删除它)已经存在的属性。我在做什么错了?

3 个答案:

答案 0 :(得分:3)

jQuery的data-*方法将信息存储在连接到该元素的jQuery对象中,并且不影响// find elements var banner = $("#banner-message") var button = $("button") // handle click and add class button.on("click", function() { var row = $('#banner-message').find('.test:first').clone(true); row.removeAttr('data-event-num'); row.attr('data-event-num', 500); $('#banner-message').find('.test:last').after(row); })属性。数据属性只是属性,您应该使用.attr().removeAttr()来添加/更改或删除它们。

body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}

#banner-message {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  font-size: 25px;
  text-align: center;
  transition: all 0.2s;
  margin: 0 auto;
  width: 300px;
}

button {
  background: #0084ff;
  border: none;
  border-radius: 5px;
  padding: 8px 14px;
  font-size: 15px;
  color: #fff;
}

#banner-message.alt {
  background: #0084ff;
  color: #fff;
  margin-top: 40px;
  width: 200px;
}

#banner-message.alt button {
  background: #fff;
  color: #000;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="banner-message">
  <p>Hello World</p>
  <button class="test" data-event-num='0'>Change color</button>
</div>
{{1}}

答案 1 :(得分:1)

摘自removeData的jQuery文档

  

请注意,.removeData()只会从jQuery的内部.data()缓存中删除数据,并且不会删除元素上任何相应的data-属性。

尝试使用

row.removeAttr('data-event-num');

代替

答案 2 :(得分:1)

使用row.attr('data-event-num', null);删除数据属性

// find elements
var banner = $("#banner-message")
var button = $("button")

// handle click and add class
button.on("click", function(){
  var row = $('#banner-message').find('.test:first').clone(true);
  //row.removeData('event-num');
  row.attr('data-event-num', null);
  $('#banner-message').find('.test:last').after(row);
})