0

我正在尝试找到使列表元素在双击时可编辑的最佳方法。如果我有这样的设置:jsfiddle

HTML

<ul>
    <li>Hello</li>
    <li>World</li>
</ul>

JS

$('li').dblclick(function() {
   //something here?
});

编写双击操作以让我更改单击的列表元素的值的最佳方法是什么?

4

3 回答 3

6

这使用contentEditable

$('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()
});

http://jsfiddle.net/sjfqX/9/

编辑

添加了焦点()。谢谢@L105

于 2013-08-23T01:30:07.240 回答
2

在 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');
     }
});

演示

于 2013-08-23T01:52:25.073 回答
1

演示

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);
    });
});
于 2013-08-23T01:22:32.380 回答