3

我有以下代码使

for(somecollection){
    <ol id="someId@(index)" class="selectableList">
       <li value="1">1</li>
       <li value="2">2</li>
       <li value="3">3</li>
    </ol>
}

在 javascript 部分:

$(".selectableList").selectable(
            {
                stop: function (event, ui) {
                    $(".ui-selected:first", this).each(function () {
                        $(this).siblings().removeClass("ui-selected");
                        var refreshVal = $(this).attr("value");
                        var cid = $(this).attr("id");
                        SetValue(@(Model.Id),refreshVal, cid);
                    });
                }
            }
        );

$("#positionCultureForm").on("submit", function () {
        if (!$(this).valid()) {
            return false;
        }
    });

我不确定如何为此设置验证,以便在提交表单时检查是否至少有一个项目是ui-selected

已编辑:我需要对集​​合中的每个项目进行单独的验证。

编辑:自定义验证:

jQuery.validator.messages.required = "";

    $.validator.addMethod("isOneSelected", function (value, element, arg) {
        return false;
    }, 'test');


    $("#someForm").validate();

    $("#someForm").on("submit", function () {
        if (!$(this).valid()) {
            return false;
        }
    });

在 HTML 中:

<ol id="someId@(index)" class="selectableList isOneSelected">
4

1 回答 1

1

应用 .selectable() 后,您的 ol 将与此类似:

<ol id="someId@(index)" class="selectableList ui-selectable">
<li class="ui-widget-content ui-selectee">Item 1</li>
<li class="ui-widget-content ui-selectee">Item 2</li>
<li class="ui-widget-content ui-selectee">Item 3</li>
<li class="ui-widget-content ui-selectee ui-selected">Item 4</li>
<li class="ui-widget-content ui-selectee">Item 5</li>
<li class="ui-widget-content ui-selectee">Item 6</li>
<li class="ui-widget-content ui-selectee">Item 7</li>
</ol>

从那里你可以看到 .ui-selected 类出现了,要找出有多少被选中,只需创建一个选择器并使用 .length 来获取它返回的项目数。

if($("#someId@(index) .ui-selected").length){} // if 1 or more are selected

如果你需要为它们中的每一个做一些特别的事情,你总是可以循环遍历它。

$("#someId@(index) .ui-selected").each(function()
{
    // your validation
}

在您的代码中,您似乎正在删除此类,.removeClass("ui-selected"); 然后您可以简单地$(this).addClass("foo")使用 .foo 制作您的选择器

于 2012-08-14T18:30:45.527 回答