我对 Amyth 的回答稍加摆弄。这只是让您单击文本进行编辑。您只需向任何文本元素添加一个类即可启用该功能。Enter 键更新文本。在输入外部单击以中止。
HTML:
<span class="edit-on-click">Click to edit</span>
JS:
$(document).ready(function() {
  $('.edit-on-click').click(function() {
    var $text = $(this),
      $input = $('<input type="text" />')
    $text.hide()
      .after($input);
    $input.val($text.html()).show().focus()
      .keypress(function(e) {
        var key = e.which
        if (key == 13) // enter key
        {
          $input.hide();
          $text.html($input.val())
            .show();
          return false;
        }
      })
      .focusout(function() {
        $input.hide();
        $text.show();
      })
  });
});
JSFiddle
更新(实现 AJAX 更新 db 值):
以下是我在实践中最终使用它的方式:它使用原始元素上的数据属性来更新 ajax 请求中的 id、model 和 field。(这是来自使用 Bootstrap 的 Django 应用程序,因此根据您的设置,某些行可能已过时。)
HTML:
<span onclick="editOnClick(this)" 
      data-id="123" 
      data-model="myapp.MyModel" 
      data-field="my_field">Click to edit</span>
JS:
function editOnClick(el) {
    var $text = $(el),
            $input = $('<input type="text" />');
    $text.hide()
            .after($input);
    $input.val($.trim($text.html())).show()
            .tooltip({title:"press ENTER to save<br>click outside to cancel", container:"body", trigger:'focus', html:true})
            .focus()
            .keypress(function(e) {
                var key = e.which;
                if (key == 13) // enter key
                {
                    $.ajax({
                        type: "POST",
                        data: {
                            value:$input.val(),
                            obj_id:$text.attr('data-id'),
                            obj_model:$text.attr('data-model'),
                            obj_field:$text.attr('data-field'),
                            csrfmiddlewaretoken:'{{ csrf_token }}'
                        },
                        url: "{% url 'edit_on_click' %}",
                        cache: false,
                        dataType: "html",
                        success: function(html, textStatus) {
                            $input.hide();
                            $text.html(html)
                                    .show();
                        },
                        error: function (XMLHttpRequest, textStatus, errorThrown) {
                            alert('Error: ' + XMLHttpRequest.responseText)
                        }
                    });
                    return false;
                }
            })
            .focusout(function() {
                $input.hide();
                $text.show();
            })
}