在Django视图中使用jquery ajax发布表的行数据

时间:2013-12-11 13:23:18

标签: javascript jquery python-2.7 django-templates django-views

这是我的观点

    def endpointdetails(request): 
          return HttpResponse("Finally I have redirected.MY values are here)

这是我的模板

HTML

    <TITLE> Add/Remove dynamic rows in HTML table </TITLE>  
   <script src="http://code.jquery.com/jquery-1.9.1.js"></script>
     <div><table><tr><td><input type="button" value="Add Row" onclick="addRow('dataTable')" /></td><td><input type="button" value="Delete Row" onclick="removeRow()" /></td></tr></table></div>
    <form id = "Endpoint" name="myForm" action = '/endpointdetails/' method = "POST">{% csrf_token %}

        <table id="dataTable" style = "border-collapse:collapse;width:1100px;" border="1">


            <tr><td style='width:60px;'>
   <input type="checkbox" name="chk" class="check" ></td><td style='width:130px;'>              <span></span>

  <input type='text' class = 'productname' style='display:none;width:150px;'                                      value="Product Name">
  </td><td style='width:130px;'><span></span><input type='text' class = 'endpoint' style='display:none;width:150px;' value="EndPoint Name"></td><td style='width:130px;'>  
    <span></span><input type='text' class = 'ipaddress'  style='display:none;width:150px;' value="IP Address"></td><td style='width:130px;'>
    <span></span><input type='text' class = 'server' style='display:none;width:150px;' value="ServerName"></td>
     <td style='width:130px;'><span></span><input type='text' class = 'Hmsg' style='display:none;width:150px;' value="Actual High Message"></td>
     <td style='width:130px;'><span></span><input type='text' class = 'lmsg' style='display:none;width:150px;' value="Actual Low Message"></td>
    <td style='width:130px;'>        
    <input type='button' id='edit' value='Edit' onclick='editRow(this);'><input type='button'   id='update' value='Update' onclick='updateRow(this);' style='display:none;'>
    </td></tr>

        </table> 
        </form> 

CSS:

   <style type="text/css">
        .democlass{
            color:red;
        }
    </style>

脚本:

    <SCRIPT type="text/javascript" language="javascript">

        function addRow() { var rowCount = $("#dataTable tr").length;            
        rowCount = parseInt(rowCount)-1; $("#dataTable tr:eq("+rowCount+")").after("<tr><td  
         style='width:60px;'><input type='checkbox' name='chk' class='check'></td><td  
          style='width:130px;'><span></span><input type='text' class = 'productname'  
         style='display:none;width:150px;' value='Product Name'></td><td style='width:130px;'><span>
         </span><input type='text' class = 'endpoint' style='display:none;width:150px;' 
         value='EndPoint Name'></td><td style='width:130px;'><span></span><input type='text' class =   
         'ipaddress' style='display:none;width:150px;' value='IPAddress'></td><td 
          style='width:130px;'><span></span><input type='text' class = 'server'  
         style='display:none;width:150px;' value='ServerName'></td><td style='width:130px;'><span>       
         </span><input type='text' class = 'Hmsg' style='display:none;width:150px;'     
        value='ActualHighMessage'></td><td style='width:130px;'><span></span><input type='text'  
   class = 'lmsg' style='display:none;width:150px;' value='Actual Low Message'></td><td 
       style='width:130px;'><input type='button' id='edit' value='Edit'  

       onclick='editRow(this);'><input type='button' id='update' value='Update'    
          onclick='updateRow(this);' 
             style='display:none;'></td></tr>");
        }
                function removeRow() {          
               $(".check").each(function(i,obj){
                if($(obj).is(":checked")){
                    if($("#dataTable tr").length > 1)
                        $(obj).parent().parent().remove();
                }           });         }

        function editRow(object) { var rowObj = $(object).parent().parent();            $(rowObj).find("td").each(function(i,obj){
                $(obj).find("span").hide('fast',function(){
                    $(obj).find("input").show('slow');
                });             });               
             $(object).parent().find("input#edit").hide('fast',function(){
                $(object).parent().find("input#update").show('slow');           
            });         }

                function updateRow(object) {
            alert(csrftoken); 
       var rowObj = $(object).parent().parent();                                       
       var prodname,endpoint,ip,server,Hmsg,lmsg;           $(rowObj).find("td").each(function(i,obj){
                if(i==1)
                    prodname = $(obj).find("input.productname").val();
                if(i==2)
                    endpoint = $(obj).find("input.endpoint").val();
                if(i==3)
                    ip = $(obj).find("input.ipaddress").val();
                if(i==4)
                    server = $(obj).find("input.server").val();
                if(i==5)
                    Hmsg = $(obj).find("input.Hmsg").val();
                if(i==6)
                    lsmg = $(obj).find("input.lmsg").val();             });


            $.post("/endpointdetails/",{Hmsg:Hmsg,lmsg:lmsg} ,function(received){             
             alert(received); });

                }


    </script>

我已尝试过上述代码,无法重定向到视图。

我已阅读有关CSRF的Django文档,但无法理解如何使用它。

任何人都可以解释一下是什么问题

1 个答案:

答案 0 :(得分:0)

如果其CSRF问题...然后在您的帖子数据中再添加一个参数csrfmiddlewaretoken,如下所示,您的代码就可以了。

$.post("/endpointdetails/",
          {'Hmsg':Hmsg, 'lmsg':lmsg, 'csrfmiddlewaretoken':$("input[name='csrfmiddlewaretoken']").val()} ,function(received){             
             alert(received); });