15

对于自定义图像选择工具,我想创建基于 html 5 表单验证的表单验证。

例如,我的表单由以下元素组成:

<form class="cms-form" action="">
    <table width="800">
        <tr>
            <td width="30%">Name:</td>
            <td><input type="text" name="name" class="cms-input-text" maxlength="127" /></td>
        </tr>
        <tr>
            <td>Image:</td>
            <td><textarea name="icon" class="cms-input-file" data-file-resource="images" data-options="{&quot;min&quot;:1,&quot;max&quot;:3}">/location-to-image.png</textarea></td>
        </tr>
        <tr>
            <td></td>
            <td><input type="submit" value="Next"/></td>
        </tr>
    </table>
</form>

我有一个 Javascript 将 textarea (.cms-input-file) 更改为一些 html 以添加图像并隐藏原始 textarea。它看起来像这样:

<textarea name="icon" class="cms-input-file" data-file-resource="images" data-options="{&quot;min&quot;:1,&quot;max&quot;:3}" style="display: none;">/location-to-image.png</textarea>
<ul class="cms-input-file-list">
    <li class="cms-input-file-item" data-image="/location-to-image.png">
        <img src="/location-to-thumb.png" alt="" class="cms-input-file-item-thumbnail"/>
        <span class="cms-input-file-item-title">location to image</span>
    </li>
    <li class="cms-input-file-add">Add</li>
</ul>

由于我已经使用 html5 表单验证分配了现有表单,因此我想使用支持 html5 的浏览器中的默认表单验证来验证此元素,但使用希望存在的事件。

我正在寻找这样的东西:

$('.cms-input-file').on('customValidateFunction', function () {
    var options = $(this).data('options');

    if($(this).find('> li.cms-input-file-item').length < options.min)
    {
        return [false, 'Add more images.'];
    }

    if($(this).find('> li.cms-input-file-item').length > options.max)
    {
        return [false, 'Remove some images.'];
    }

    return true;
});

有谁知道使用默认的 html 5 事件是否可以实现这样的事情,或者我将如何将此事件添加到提交事件中?实际触发默认浏览器验证外观。

- 编辑 -

到目前为止,我已经尝试使用隐藏原始元素的 div 元素来获得此结果。但是现在我需要根据我的选项向元素添加一个模式来匹配。这可能吗?

当前进度:http: //jsfiddle.net/jeffreydev/YyEVu/

4

3 回答 3

5

如果我正确理解您的需求,我认为您可以使用任何输入元素的模式属性来实现您想要做的事情。

在 jsfiddle 中创建了一个非常简单的表单来说明这一点。

这个想法是,在添加或删除图像时,您可以使用模型中的任何数据来更新输入的值。该示例只为每个图标添加一个字母f 。然后,您可以创建一个正则表达式来匹配预期的有效结果。在示例中,pattern="f{1,3}"表示要有效,内容可以是“f”、“ff”或“fff”,但不能是其他任何内容,这意味着它只会接受来自一个要发送的三个文件。

您将只使用默认的 html5 表单验证,但您可能需要进行一些调整才能使其正常工作。

但是,如果您尝试这种方式,您应该记住以下几点:

  1. 规范中所述,该模式被编译为 JavaScript 正则表达式,禁用了 global、ignoreCase 和 multiline 标志
  2. 设置输入的 disabled 属性,以便用户无法更改它会将其从表单中取出,因此不会被验证
  3. 当验证失败并且浏览器试图获得对元素的关注时,将某些样式作为 *display:none" 应用到输入元素可能会导致错误。

我希望这对你有帮助

于 2012-08-28T01:30:45.430 回答
3

您可以在 上安装submit处理程序<form>,并从那里分派自定义事件。

这看起来像这样:

$('form.cms-form').on('submit', function(evt) {
    var frm = $(this);
    var allElements = $(this.elements);
    $('#errors').empty();   

    var errors = [];
    var arg = {
        reportValidationError : function( msg ) {
            errors.push(msg);
        },
        form : this
    };
    console.log("all elements: ", allElements);
    allElements.trigger('customValidate', [ arg ]);

    if( errors.length !== 0 ) {
        showValidationErrors(errors);
        return false;
    }
    return true;
});

然后,您可以“挂钩”customValidate事件,并安装自己的逻辑......

$('textarea[name=icon]').on('customValidate', function(evt, reporter) {
    var options = $(this).data('options');

    // ... your validation here ...

    // for example:
    var txt = $(this).val();
    if( txt.length < options.min || txt.length > options.max ) {
        reporter.reportValidationError('error: "icon" min/max exceeded!');
    }
})

这是 jsFiddle 的一个示例


编辑

您可以设置错误报告的样式,并调整代码,使其外观和行为符合您的要求。 这是一个例子

于 2012-08-23T08:21:10.647 回答
0

Mike Alsup 是一个非常好的验证表单的 jquery 插件。你会在这里找到它:http: //jquery.malsup.com/form/

它已记录在案,与 ajax 兼容。

它可以对表单中的一个字段或所有字段进行序列化,因此对于您可能需要使用表单处理字段验证和错误逻辑的问题,这是一个很大的优势。

您可以添加同作者的blockUI插件来提升用户体验,并且在启用javascript时不必管理表单的双重提交。 http://jquery.malsup.com/block/

于 2012-08-29T09:02:35.717 回答