我正在尝试找到使列表元素在双击时可编辑的最佳方法。如果我有这样的设置:jsfiddle
HTML
<ul>
<li>Hello</li>
<li>World</li>
</ul>
JS
$('li').dblclick(function() {
//something here?
});
编写双击操作以让我更改单击的列表元素的值的最佳方法是什么?
我正在尝试找到使列表元素在双击时可编辑的最佳方法。如果我有这样的设置:jsfiddle
HTML
<ul>
<li>Hello</li>
<li>World</li>
</ul>
JS
$('li').dblclick(function() {
//something here?
});
编写双击操作以让我更改单击的列表元素的值的最佳方法是什么?
$('li').dblclick(function() {
this.contentEditable=true
$(this).on('keypress blur', function(e) {
if(e.keyCode&&e.keyCode==13||e.type=='blur'){
this.contentEditable=false
return false
}
});
$(this).focus()
});
编辑
添加了焦点()。谢谢@L105
在 HTML5 中,您可以使用contenteditable
. 绑定点击window
删除属性。
编辑-我结合了一些答案,这应该可以完成工作:
$('li').on({
dblclick: function() {
$(this).attr('contenteditable', 'true').focus();
},
keydown : function(e) {
if(e.keyCode && e.keyCode === 13) {
e.preventDefault();
$(this).blur();
}
},
blur: function() {
$(this).removeAttr('contenteditable');
}
});
var $elem = $(this);
var mytext = $elem.text();
$elem.html('<input type="text" class="foo" value="' + mytext + '" />');
$('li').dblclick(function() {
var $elem = $(this);
var mytext = $elem.text();
$elem.html('<input type="text" class="foo" value="' + mytext + '" /> <span class="save">Save!</span>');
$(".save").click(function() {
var mynewtext = $(this).parent().find(".foo").val();
$elem.html(mynewtext);
});
});