在编辑行的 jqGrid 列中添加掩码

Adding mask in jqGrid colum on editing line

当我使用 jqGrid(我的 jqGrid 版本是 4.5.4)添加或编辑记录时,我需要为某些列创建一个 phone 掩码。

下面是我的代码:

this.montarGRID = function (p_gridName, p_dados, p_header, p_descriptor, p_contentName, p_primaryKey, p_filtroGrid) {
jQuery("#" + p_gridName).jqGrid( {
    data : p_dados, 
    datatype : "local", 
    sortable : true, 
    colNames : p_header, 
    colModel : p_descriptor,
...

此网格是动态生成的。我传递了一个包含 colModel.

内容的 json
[
{"formatter":"integer","index":"id","hidden":true,"sortable":true,"sorttype":"integer","width":75,"align":"center","name":"id"},
{"formatter":"telefone","index":"TELCONTATO01","search":true,"hidden":false,"sorttype":"text","sortable":true,"width":0,"align":"right","name":"TELCONTATO01","editoptions":{"text":true,"required":false,"dataInit":"function (elem) {  return mostra_telefone(elem); }"},"editrules":{"text":true,"required":false,"dataInit":"function (elem) {  return mostra_telefone(elem); }"},"editable":true},
{"formatter":"telefone","index":"TELCONTATO02","search":true,"hidden":false,"sorttype":"text","sortable":true,"width":0,"align":"right","name":"TELCONTATO02","editoptions":{"text":true,"required":false,"dataInit":"function (elem) {  return mostra_telefone(elem); }"},"editrules":{"text":true,"required":false,"dataInit":"function (elem) {  return mostra_telefone(elem); }"},"editable":true}
]

生成phone掩码的方法...

(function($) {
    'use strict';
    $.extend($.fn.fmatter, {
        mostra_telefone : function (elem) {
            $(elem).mask("(99)9999-9999?");
        }
    });
})(jQuery);

但是当我select、更改或添加记录时它从未被调用。

这是一段执行所需行为的代码。为此,我们使用 inputpask 插件。 $("#jqGrid").jqGrid({ ... colModel :[

                {
                    name: 'Telephone',
                    width: 100,
                    formatter: function(cellvalue, options, rowObject) {
                        var re = new RegExp("([0-9]{3})([0-9]{3})([0-9]{4,6})", "g");
                        return cellvalue.replace(re, "() -"); 
                    },
                    unformat : function(cellvalue, options, rowObject) {
                        return cellvalue.replace("(",'').replace(") ",'').replace("-",'');
                    },
                    editable: true,
                    edittype: "custom",
                    editoptions :{
                        custom_element : function(value, options) {
                            var el = document.createElement("input");
                            el.type="text";
                            el.value = value;
                            $(el).addClass('inline-edit-cell ui-widget-content ui-corner-all').inputmask({"mask": "(999) 999-9999"});
                            return el;                              
                        },
                        custom_value : function(elem, operation, value) {
                            if(operation === 'get') {
                                return $(elem).val().replace("(",'').replace(") ",'').replace("-",'').replace(/\_/g,'');;
                            } else if(operation === 'set') {
                                $(elem).val(value);
                            }                               
                        }
                    },
                    editrules : {
                        requiered : true,
                        custom : true,
                        custom_func : function(val, name) {
                            // special replace mask at end
                            var cel  = val.replace("(",'').replace(") ",'').replace("-",'').replace(/\_/g,'');
                            if(cel.length !== 10) {
                                return [false,"Please, enter correct phone number"];
                            } 
                            return [true,""];
                        }
                    }   
                },                  

          ....
       ],
    ....
});

此代码也应该适用于您的版本。 这里还有一个 link to the demo.

我用这个解决了问题:

function custom_element_telefone(value, options){
    var el = document.createElement("input");
    el.type="text";
    el.value = value;
    $(el).addClass('inline-edit-cell ui-widget-content ui-corner-all').inputmask({"mask": "(99)9999-9999#"});
    return el;
};

this.montarGRID = function (p_gridName, p_dados, p_header, p_descriptor, p_contentName, p_primaryKey, p_filtroGrid) {

    p_descriptor.forEach(col => {
        if (!col.editoptions) return;
        if (!col.editoptions.custom_element) return;

        switch (col.editoptions.custom_element) {
            case "custom_element_telefone":
                col.editoptions.custom_element = custom_element_telefone;
                break;            
        }
    });

    jQuery("#" + p_gridName).jqGrid( {
        data : p_dados, 
        datatype : "local", 
        sortable : true, 
        colNames : p_header, 
        colModel : p_descriptor,
...