添加-编辑-删除按钮不工作

jqGrid | add-edit-delete buttons not working

本文关键字:工作 按钮 删除 编辑 添加      更新时间:2023-09-26

对不起,如果我的问题很简单,我对jqGrid完全陌生:)

1-我想使用(添加,编辑,删除)jqGrid的功能,正如你所看到的,在我的网格的页脚部分有按钮,但是当我点击一个对话框来了,没有字段输入!!我要跟这一页一样看看我的屏幕图片!

2-当我点击提交按钮(修复第1部分后),我想知道数据是如何发布到服务器的!不管是什么语言,我都不想比如它们作为对象或STH发送,要知道如何处理它们!

tnx很多

我的源代码:

{% load static %}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Index Page</title>
    <!-- external scripts -->
    <!-- jQuery & Bootstrap -->
    <script type="text/javascript" src="{% static "js/jquery.js" %}"/></script>
        <script type="text/javascript" src="{% static "js/jquery.jqGrid.min.js" %}"/></script>
    <link rel="stylesheet" type="text/css" media="all" href="{% static "css/bootstrap.min.css?id=1" %}"/>
    <script type="text/javascript" src="{% static "js/bootstrap.min.js" %}"/></script>
    <!-- jQuery & Bootstrap -->
    <!-- jqGrid -->
    <link rel="stylesheet" type="text/css" media="screen" href="{% static "css/ui.jqgrid.css" %}" />
    <link rel="stylesheet" type="text/css" media="screen" href="{% static "css/ui-lightness/jquery-ui.min.css" %}" />
    <script type="text/javascript" src="{% static "js/grid.locale-en.js" %}"/></script>
    <!-- jqGrid -->
    <!-- own implemented scripts -->
    <script type="text/javascript" src="{% static "js/script.js" %}"/></script>  
    <!-- own implemented scripts -->
    <!-- external scripts-->
    <script type="text/javascript">
    $(function () {
        $("#list").jqGrid({
            url: "http://localhost:8000/getdata",
            datatype: "json",
            mtype: "GET",
            colNames: ["شناسه", "کد","نام", "عنوان" ,"عنوان انگلیسی", "ظرفیت", "ظرفیت اضافه","قیمت روز"],
            colModel: [
                  { name: "id", index:"id", width: 60 , editable:true,editoptions: {readonly: "readonly"}},
            { name: "code", width: 60 , editable:true},
            { name: "name", width: 90 , editable:true},
            { name: "title", width: 90 ,editable:"true", editable:true},
            { name: "english_title", width: 100, align: "left", editable:true },
            { name: "capacity", width: 90, align: "left", editable:true },
            { name: "extra_capacity", width: 90, align: "left", editable:true },
            { name: "today_price", width: 80, align: "left" , editable:true},
            ],
            rowNum:10,
            rowList:[10,20,30],
            pager: '#pager',
            loadonce:true,
            sortname: 'id',
            viewrecords: true,
            sortorder: "desc",
            rownumbers: true,
            rownumWidth: 40,
            gridview: true,
            multiselect: false,
            caption: "اتاق ها",
            onSelectRow: function(ids) {
                if(ids == null) {
                    ids=0;
                    if(jQuery("#list_d").jqGrid('getGridParam','records') >0 )
                    {
                        jQuery("#list_d").jqGrid('setGridParam',{url:"getpricelist?q=1&id="+ids,page:1}).trigger('reloadGrid');
                    }
                } else {
                    jQuery("#list_d").jqGrid('setGridParam',{url:"getpricelist?q=1&id="+ids,page:1}).trigger('reloadGrid');
                jQuery("#list_d").jqGrid('setCaption',"لیست قیمت اتاق شماره : "+ids)
                }
            }
     });
    jQuery("#list").jqGrid('navGrid','#pager',{edit:true,add:true,del:true,search:false},
     /*   {
                    recreateForm: true,
                    beforeShowForm: function ($form) {
                        $form.find(".FormElement[readonly]")
                            .prop("disabled", true)
                            .addClass("ui-state-disabled")
                            .closest(".DataTD")
                            .prev(".CaptionTD")
                            .prop("disabled", true)
                            .addClass("ui-state-disabled")
                    },
        }, */
     //edit options
       { // Edit option (parameters of editGridRow method)
        recreateForm:true,
        reloadAfterSubmit:true,
        closeOnEscape:true,
        savekey: [true,13],
        closeAfterEdit:true,
        url:'/edit',
        ajaxEditOptions: {
            beforeSend: function(jqXHR) {
                var csrf_token = getCookie('csrftoken'); 
                jqXHR.setRequestHeader('X-CSRF-Token', csrf_token);
            }
        },
            afterSubmit: function () {
             jQuery("#list").jqGrid("setGridParam", {datatype: 'json'});
             console.log('changed data type');
             return [true];
         },
        editData: {
            csrfmiddlewaretoken: getCookie('csrftoken')
        }
    },
    //add options
    { 
        recreateForm:true,
        reloadAfterSubmit:true,
        closeOnEscape:true,
        savekey: [true,13],
        closeAfterAdd: true,
        url:'/add',
        ajaxEditOptions: {
            beforeSend: function(jqXHR) {
                var csrf_token = getCookie('csrftoken'); 
                jqXHR.setRequestHeader('X-CSRF-Token', csrf_token);
            }
        },
            afterSubmit: function () {
             jQuery("#list").jqGrid("setGridParam", {datatype: 'json'});
             console.log('changed data type');
             return [true];
         },
        editData: {
            csrfmiddlewaretoken: getCookie('csrftoken')
        }
    },
    //delete options
    { 
        recreateForm:true,
        reloadAfterSubmit:true,
        closeOnEscape:true,
        savekey: [true,13],
        url:'/delete',
        ajaxEditOptions: {
            beforeSend: function(jqXHR) {
                var csrf_token = getCookie('csrftoken'); 
                jqXHR.setRequestHeader('X-CSRF-Token', csrf_token);
            }
        },
        afterSubmit: function () {
             jQuery("#list").jqGrid("setGridParam", {datatype: 'json'});
             console.log('changed data type');
             return [true];
         },
        editData: {
            csrfmiddlewaretoken: getCookie('csrftoken')
        }
    }
    );
  jQuery("#list").jqGrid('filterToolbar',{stringResult: true,searchOnEnter : false});
    jQuery("#list_d").jqGrid({
        height: 100,
    width:345,
        url:'getpricelist?q=1&id=2',
        datatype: "json",
        colNames:['از','تا', 'قیمت'],
        colModel:[
    {name:'from',index:'from', width:100},
    {name:'to',index:'to', width:100},
    {name:'price',index:'price', width:80, align:"right"},

        ],
        rowNum:5,
        rowList:[5,10,20],
        pager: '#pager_d',
        sortname: 'item',
        viewrecords: true,
        sortorder: "asc",
        multiselect: false,
        caption:"لیست قیمت"
    }).navGrid('#pager_d',{add:false,edit:false,del:false});
        }); 
    </script>
    </head>
    <body>
        <table id="list"><tr><td></td></tr></table>
        <div id="pager"></div> 
        <table id="list_d"></table>
        <div id="pager_d"></div>
    </body>
</html>

views.py

from django.shortcuts import render
from django.utils import simplejson
from django.http import HttpResponse
from rooms.models import *
from django.db.models import Q
from django.core import serializers

def index(request):
    return render(request, 'index.html')
def getdata(request):
    data=room_type.objects.all()
    json=[]
    for o in data:
        json.append({'id':o.id, 'code':o.code,'name':o.name,'title':o.title, 
                     'english_title':o.english_title, 'capacity':o.capacity,
                     'extra_capacity':o.extra_capacity, 'today_price':o.today_price })
    return HttpResponse(simplejson.dumps(json), mimetype='application/json',content_type='application/json' )

def getpricelist(request):
    requested_room_id = request.GET.get('id', '')
    room = room_type.objects.get(id = requested_room_id)
    price_list_set = room.price_list_set.all()
    json=[]
    for price_list in price_list_set:
        json.append({'from':price_list.from_date, 'to':price_list.to_date, 'price':price_list.price})

    return HttpResponse(simplejson.dumps(json), mimetype='application/json',content_type='application/json' )
def edit(request):
    print "################ediit#################"
    return render(request, 'index.html')

def add(request):
    print "################addddddddddd#################"
    return render(request, 'index.html')

def delete(request):
    print "################deeeeeeeeeeeeeel#################"
    return render(request, 'index.html')

第一个问题很容易解决。编辑表单(Add and Edit)只包含关于可编辑列的信息。因此,您需要在您希望允许用户编辑的colModel的每一列中包含editable: true属性。

重要的是要理解默认值对于colModel的每个已知属性。我建议您检查表中文档所在位置的最后一列("Default")。您将发现align的默认值是"left",因此您可以从所有colModel项中删除align: "left"。同样,您可以看到editable属性的默认值是false。这就是为什么你的编辑表单是空的。如果您需要将editable: true设置为colModel的一半列,我建议您使用jqGrid的cmTemplate选项(请参阅答案以了解更多详细信息)。例如,在包括cmTemplate: {editable: true}选项之后,你需要在所有你不想编辑的列中包括editable: false。其他所有列都是可编辑的。

如果您需要在添加/编辑表单中包含一些列信息,但不允许用户编辑它,您可以将editable: trueeditoptions: {readonly: "readonly"}editoptions: {disabled: "disabled"}一起使用。该选项将包括编辑表单中的信息,但在相应的编辑字段上设置额外的readonly="readonly"disabled="disabled"属性。可以像答案中描述的那样在这样的文件上添加额外的"ui-state-disabled"类。通过这种方式,您可以使某些字段可编辑,但只能在添加对话框中进行编辑,并在编辑对话框中保持禁用/只读。不要忘记使用recreateForm: true选项。

为了使编辑成功,正确填充网格的行是非常重要的。如果你有一个name: "id"的列,或者如果一些列有key: true属性,那么相应的值将被用作rowid。将发送到服务器的信息描述在这里(关于编辑),这里(关于添加)和这里(关于删除)。该信息总是包含id=rowidvalue属性。添加/编辑表单发布关于表单:name=value中所有(包括隐藏)可编辑列的额外信息,其中namecolModel中列定义的name属性的值。