1

我正在使用Robin Herbot 的 jquery 输入掩码来处理我的应用程序中的一些 DateTime 内容。

我想始终显示掩码,您可以通过将clearMaskOnLostFocus属性设置为false

$.extend($.inputmask.defaults, {
    'clearMaskOnLostFocus': false
});

如果您的输入直接来自用户按下键盘,这将非常有用。当它为空时,面具仍会显示。我的问题是当它的值以textbox编程方式设置为空字符串时,它会显示一个空掩码。

$('#id').val(''); //this will remove the mask until hover or focus

在我开始修改插件之前我想问一下,希望我只是遗漏了一些东西。

这是一个演示

4

1 回答 1

1

我最终修改了内部fn.val函数,以便如果以编程方式清除元素,它会将值设置为空掩码。

$('#id').val(''); //this will set the value to an empty mask, ie __/__/____

//changes were made to this function
    $.fn.val = function ()
    {
        if (arguments.length == 0)
        {
            var $self = $(this);
            if ($self.data('_inputmask'))
            {
                if ($self.data('_inputmask')['opts'].autoUnmask)
                    return $self.inputmask('unmaskedvalue');
                else
                {
                    var result = $.inputmask.val.apply($self);
                    var inputData = $(this).data('_inputmask'), masksets = inputData['masksets'],
                        activeMasksetIndex = inputData['activeMasksetIndex'];
                    return result != masksets[activeMasksetIndex]['_buffer'].join('') ? result : '';
                }
            } else return $.inputmask.val.apply($self);
        } else
        {
            var args = arguments;
            //if there are args, and they are undefined, null or empty then use the native .val function
            if (args.length > 0 && isNullOrEmpty(args[0]))
            {
                return $.inputmask.val.apply($(this));
            }
            else
            {
                return this.each(function ()
                {
                    var $self = $(this);
                    var result = $.inputmask.val.apply($self, args);
                    if ($self.data('_inputmask'))
                        $self.triggerHandler('setvalue.inputmask');
                    return result;
                });
            }
        }
于 2013-08-06T17:41:00.557 回答