Reputation: 1898
I have set contenteditable="true"
to ul
, and I have a list inside this.
As you can see before each list I've set checkboxes
. If I click on checkbox, it toggles class checked
. The problem is, when I click checkbox, and press enter, it adds same class checked
to this added list.
I don't want added list to be checked. Is there anyway to prevent this?
Thank you in advance!
$(document).ready(function(){
$(document).on('click', 'ul li', function(){
$(this).toggleClass('checked');
})
$(document).on('click', 'ul li span', function(e){
e.stopPropagation();
})
});
li:before {
background-image: url('');
display: block;
float: left;
content: "";
width: 18px;
height: 18px;
background-size: 100%;
}
li {
list-style: none;
margin-bottom: 14px;
height: 22px;
position: relative;
width: 99%;
}
li.checked:before {
background-image: url('');
background-size: 100%;
width: 18px;
height: 18px;
background-repeat: no-repeat;
}
li span {
display: inline-block;
width:90%;
margin-left: 10px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<ul contenteditable="true" id="editor">
<li>
<span>
Click on checbox and press enter
</span>
</li>
</ul>
Upvotes: 1
Views: 104
Reputation: 1898
I found the right solution of my answer: The solution was listening DOMNodeInserted
event:
$('#editor').on('DOMNodeInserted', function(e) {
$(e.target).removeClass('checked');
});
Upvotes: 0
Reputation: 2224
Update: Based on your requirements you can add an event listener to detect any change in the ul
section and remove the class from the last li
tag
$(document).ready(function(){
$(document).on('click', 'ul li', function(){
$(this).toggleClass('checked');
});
$(document).on('click', 'ul li span', function(e){
e.stopPropagation();
});
$('#editor').on('input', function(){
$(this).children('li').last().removeClass('checked');
});
});
You don't have to even check the checkbox, you can edit the contents anyway. That's because you've set the property of the ul in such a way contenteditable="true"
. I'm not sure why you'd want that but if you must, then you can disable this property after the checkbox has been checked
$(document).ready(function(){
$(document).on('click', 'ul li', function(){
var $this = $(this);
$this.toggleClass('checked');
if($this.hasClass('checked')){
$this.parent().attr('contenteditable', false);
}
else {
$this.parent().attr('contenteditable', true);
}
})
$(document).on('click', 'ul li span', function(e){
e.stopPropagation();
})
});
Upvotes: 1