Javascript 单击Django中的编辑表单字段并在数据库中更新

Javascript 单击Django中的编辑表单字段并在数据库中更新,javascript,jquery,django,forms,Javascript,Jquery,Django,Forms,这是我要找的。 我有一个UpdateView,它使用从数据库加载的字段从CreateView呈现表单。相反,我的编辑表单具有只读html属性。所以我需要的是在点击表单字段时删除readonly,当我输入新值时,当光标移动到下一个字段时,它将自动更新 如何在没有提交按钮的情况下处理POST操作?您可以使用JavaScript(Jquery)来执行此操作,blurevent 编辑:关于CSRF验证,请参阅 关于$。post请参阅: template.html <script type="tex

这是我要找的。 我有一个UpdateView,它使用从数据库加载的字段从CreateView呈现表单。相反,我的编辑表单具有只读html属性。所以我需要的是在点击表单字段时删除readonly,当我输入新值时,当光标移动到下一个字段时,它将自动更新

如何在没有提交按钮的情况下处理POST操作?

您可以使用JavaScript(Jquery)来执行此操作,
blur
event

编辑:关于CSRF验证,请参阅

关于
$。post
请参阅:

template.html

<script type="text/javascript" src="/media/js/jquery-1.10.2.min.js"></script>
<script>
// using jQuery
function getCookie(name) {
  var cookieValue = null;
  if (document.cookie && document.cookie != '') {
    var cookies = document.cookie.split(';');
    for (var i = 0; i < cookies.length; i++) {
      var cookie = jQuery.trim(cookies[i]);
      // Does this cookie string begin with the name we want?
      if (cookie.substring(0, name.length + 1) == (name + '=')) {
        cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
        break;
      }
    }
  }
  return cookieValue;
}

$(document).ready(function(){
  $("#myinput").blur(function(){
  var csrftoken = getCookie('csrftoken');
  $.ajaxSetup({
    beforeSend: function(xhr) {
      xhr.setRequestHeader("X-CSRFToken", csrftoken);
    }
  });

  $.post('/link-to-fun/',{"value":value});
  }); 
});
</script>

<input type="text" id="myinput">
views.py

def change_db_value(request):
    value = request.POST.get('value','')
    # database operation

如果否决被否决,告诉我原因。我会改变我的答案,提高自己。ThxI做到了-您已从
$.get
更改为
$.post
(这很有意义),但您没有处理CSRF,因此我认为Django在不声明安全的情况下甚至不会允许这样做(但您应该确保安全)。mouseout事件是错误的解决方案(blur似乎更合适),您绑定它的方法也严重过时。最后,我不知道你为什么要提供一个只返回服务器响应的回调。你可以一起发布CSRF值。是的,你可以,但是你的答案没有给出,谢谢你的建议。我改变了我的答案。我是个新手,有很多东西需要学习
def change_db_value(request):
    value = request.POST.get('value','')
    # database operation