如何在jqgrid中删除时显示错误消息? - c#

所有人,我正在使用jqgrid,并且如果用户想要删除正在使用的卡车记录,则想显示错误消息,我必须显示正在使用的错误消息。
这是我的jqgrid:

    jQuery(document).ready(function () {


        var grid = jQuery("#TrucksGrid141");

        grid.jqGrid({
            url: '/Admin/GetTrucksForJQGrid',
            datatype: 'json',
                mtype: 'Post',
                 cellsubmit: 'remote',
               cellurl: '/Admin/SaveTruck',
               height: '100%',
               pager: '#pagerTrucks',

            colNames: ['Id', 'Name', ''],
            colModel: [
            { name: 'Id', index: 'Id', key: true, hidden: true, editrules: { edithidden: true } },
            { name: 'Name', index: 'Name', align: "center", sorttype: 'text', resizable: true, editable: true, editrules: { required: true } },


            { name: 'Delete', index: 'Delete', width: 25, resizable: false, align: 'center', classes: 'not-editable-cell' }

            ],    



            width: '490',           
            caption: 'Company Trucks',
            hidegrid: false,
            delete: true,
            cellEdit: true,
            viewrecords: true,
            gridComplete: function () {

                var ids = grid.jqGrid('getDataIDs');
                for (var i = 0; i < ids.length; i++) {
                    var isDeleted = grid.jqGrid('getCell', ids[i], 'Delete');
                    if (isDeleted != 'true') {
                        grid.jqGrid('setCell', ids[i], 'Delete', '<a href="#" onclick="deleteRow(' + ids[i] + ');"><img src="/Images/delete.png" alt="Delete Row" /></a>');
                    }
                    else {
                        grid.jqGrid('setCell', ids[i], 'Delete', ' ');
                        //grid.jqGrid('setCell', ids[i], 'Privileges', 'admin');
                    }
                }
            }
        }

        );

        grid.jqGrid('navGrid', '#pagerTrucks',
       { resize: false, add: false,search:false, del: false, refresh: false, edit: false, alerttext: 'Please select one user' }

   ).jqGrid('navButtonAdd', '#pagerTrucks',
       { title: "Add New Truck", buttonicon: "ui-icon ui-icon-plus", onClickButton: showNewTruckModal, position: "First", caption: "" });

    });

    function showNewTruckModal() {

        var grid = jQuery("#TrucksGrid141");
        $("#formAddNewTruck").dialog(
                {
                    open: function (event, ui) {

                        $("#txtName").val('');
                        $("#trFormErrorTrucks").hide();
                        $("#trFormErrorTrucks td").text('');

                    },
                    buttons: {
                        "Submit": function () {
                            debugger;
                            if (ValidateUsers() == true) {
                                $('#error').ajaxError(function (event, request, settings) {
                                    $('#waiting').hide();
                                    $(this).addClass('errordiv').text(request.statusText + "" + request.status);

                                });
                                $.post('/Admin/AddNewTruck/',
                                $('#formAddNewTruck').serialize(),
                                function (data) {
                                    debugger;
                                    if (data == 'Success') {
                                        $('#formAddNewTruck').dialog("close");
                                        grid.jqGrid('setGridParam', { datatype: 'json' }).trigger('reloadGrid');
                                    }
                                    else {
                                        $("#trFormErrorTrucks").show();
                                        $("#trFormErrorTrucks td").text(data);
                                    }

                                });
                            }
                        },
                        "Cancel": function () {
                            $('#error').removeClass("errordiv").text("");
                            $('#waiting').hide();
                            $(this).dialog("close");
                        }
                    },
                    modal: true,
                    title: "New Truck",
                    minWidth: 400,
                    resizable: false
                }
        ).dialog('open');
    }

    function ValidateUsers() {
            var flag = true;
            var errorMSG = '';
            $("#trFormErrorTrucks td").text('');
            if ($("#txtName").val() == '') {
                errorMSG += 'Truck Name cannot be blank';
                flag = false;
            }


            if (flag == false) {
                $("#trFormErrorTrucks").show();
                $("#trFormErrorTrucks td").text(errorMSG);
            }
            else {
                $("#trFormErrorTrucks td").text('');
                $("#trFormErrorTrucks").hide();
            }
            return flag;
        }

    function deleteRow(rowid) {
        jQuery("#TrucksGrid141").delGridRow(rowid, { url: '/Admin/TruckDelete', caption: 'Delete User?', msg: 'Delete selected User? <br />Careful, this is irreversable!', resize: false,success:abc });
        }

        function emptyText(rowid, cellname, value, iRow, iCol) {
            if (cellname == 'Password')
                return "";
        }
        function abc(data)
        {
            debugger;
        }


    and here is my cs code from controller:

  [AcceptVerbs(HttpVerbs.Post)]
        public ActionResult TruckDelete(int Id)
        {
            var error = "";
            bool result=true;
            DataContext db = new DataContext();
           Truck udelete= db.Trucks.Where(el => el.Id == Id).FirstOrDefault();
           if (udelete != null)
           {
               JobSites_ForSnow snow = db.JobSites_ForSnow.Where(el => el.TruckId == Id).FirstOrDefault();
               JobSite normal = db.JobSites.Where(el => el.TruckId == Id).FirstOrDefault();
               if(snow==null && normal==null)
               {
               db.Trucks.Remove(udelete);           
               db.SaveChanges();
               }
               else
               {
                error = "Truck in use!";
               result= false;
               }
           }
           else 
           {
               error = "Record Not Found!";
               result= false;
           }
            return Json(result,error);
        }

有人可以告诉我如何显示错误消息吗?我已经看到了这个答案(jqgrid error message on delete),但不知道该怎么做:(。如果问题不清楚,请通过评论让我知道,我会提前解释...谢谢:)

参考方案

您目前使用

return Json(result,error);

作为TruckDelete操作的最后一行,其中result具有布尔类型,error是字符串。因此,Controller.Json Method (Object, String)其中error将被解释为HTTP响应的contentType。这是你的第一个问题。您应该使用类似

return Json(new Object[] {result, error});

(请参见here)。在这种情况下,该方法将生成JSON响应,例如

[true,""]

要么

[false,"Record Not Found!"]

客户端(jqGrid)可以在afterSubmit回调内部处理响应。您只需将success的未知(对于jqGrid)选项delGridRow替换为以下内容

jQuery("#TrucksGrid141").delGridRow(rowid, {
    url: '/Admin/TruckDelete',
    caption: 'Delete User?',
    msg: 'Delete selected User? <br />Careful, this is irreversable!',
    resize: false,
    afterSubmit: function (jqXHR) {
        return $.parseJSON(jqXHR.responseText); // return decoded response
    }
});

如何从php中获取datatables jQuery插件的json数据 - php

我是PHP的新手,正在尝试使用Datatables jQuery插件。我知道我必须从.php文件中获取数据,然后在数据表中使用它,但是我似乎无法通过ajax将其传递给数据表。我设法从数据库中获取数据,并对其进行json编码,但是后来我不知道如何在我的index.php文件中调用它,并在其中显示它。我究竟做错了什么?这是我的代码:HTML(已编辑): <…

如何在没有for循环的情况下在Javascript中使用Django模板标签 - javascript

我想在JavaScript中使用模板变量:我的问题是在javascript代码中使用for循环,for循环之间的所有事情都会重复..但我不想要....下面粘贴了我的代码..有人可以告诉我更好的方法吗这..因为这看起来很丑..这是我的代码: {% block extra_javascript %} <script src="/static/js…

Mongo抛出“元素名称'名称'无效”异常 - c#

我正在更新一个简单的字段。var filterDocument = new BsonDocument { { "name", "alice" } }; var newDocument = new BsonDocument { { "name", "Alice" } }; coll…

T-SQL等价的正则表达式'\ b' - c#

我正在将利用regex的CLR函数转换为SQL函数。我知道SQL Server并不完全支持正则表达式,但是我只需要一种情况就可以搜索单词。搜索字段值:{"Id":1234, "Title": "The quick brown"}.NET中的正则表达式模式:'\b' + '…

如何在数据表中显示错误消息 - php

我将Datatable用于我的候选人列表,并使用地区和政党名称搜索候选人。我为此使用ajax。问题是,当没有任何搜索结果时,我无法显示“未找到结果”。我该怎么做?码:单击搜索按钮时:$(document).on("click", "#submit_filter", function(){ $(this).attr(&#…