c# - 可排序、可拖动、可排序的表 + mvc 未正确更新顺序

原文 标签 c# asp.net-mvc jquery-ui-sortable draggable

我正在尝试在我的 View 中添加一个可订购的表。在 View New.cshtml 中进行排序时,排序有效。它使用 jQuerys sortable .如果我添加一些指令(在这种情况下为 1-5),我可以通过可排序的脚本来移动它们。但是,当我尝试在重新排序后添加新指令时,顺序会从:

enter image description here



enter image description here

我想这与隐藏形式有关

@Html.HiddenFor(m => m.Recipe.Instructions[i].Number, new { @id = "Number"})

当我重新排序可排序表中的字段时,它需要更新其值。

我在这里想念什么?

食谱 Controller .cs
public ActionResult Create(NewRecipeViewModel viewModel, string command)
{

//...more code...

    var instructionList = new List<Instruction>();

    if (viewModel.Recipe.Instructions != null)
    {
        for (int i = 0; i < viewModel.Recipe.Instructions.Count; i++)
        {
            var instruction = new Instruction
            {
                Id = viewModel.Recipe.Instructions[i].Id,
                Name = viewModel.Recipe.Instructions[i].Name,
                Number = viewModel.Recipe.Instructions[i].Number

            };
            instructionList.Add(instruction);
        }
    }

    if (command.Equals("AddInstruction"))
    {
        var instruction = new Instruction
        {
            Name = viewModel.NewInstruction.Name,
            Number = viewModel.Recipe.Instructions.Count + 1
        };

        recipe.Instructions.Add(instruction);
        viewModel.Recipe = recipe;

        return View("New", viewModel);
    }

//...more code...
}

新建.cshtml
<div class="form-group" style="margin-top: 170px;">
    <label class="col-md-2 control-label">
        Lägg till instruktion:
    </label>
    <div class="col-md-10">
        @Html.TextBoxFor(m => m.NewInstruction.Name, new { @class = "form-control" })
    </div>
</div>
<div class="form-group" style="margin-top: 300px;">
    <label class="col-md-2 control-label">
    </label>
    <div class="col-md-10">
        <button type="submit" name="command" value="AddInstruction" class="btn btn-primary">Add instruction</button>
    </div>
</div>
<div class="form-group" style="margin-top: 100px;">

    <label class="col-md-2 control-label">
        Instructions:
    </label>
    <div class="col-md-10">
        <table class="table table-bordered table-hover pagin-table" style="margin-top: 10px">
            <thead>
                <tr bgcolor="#f5f5f5">
                    <th>Order:</th>
                    <th>Instruction:</th>
                </tr>
            </thead>
            <tbody id="sortable">
                @if (Model.Recipe.Instructions != null)
                {
                    for (int i = 0; i < Model.Recipe.Instructions.Count; i++)
                    {
                        <tr>
                            @Html.HiddenFor(m => Model.Recipe.Instructions[i].Id)
                            <td class="order">
                                @Model.Recipe.Instructions[i].Number
                                @Html.HiddenFor(m => m.Recipe.Instructions[i].Number, new { @id = "Number"})
                            </td>
                            <td>
                                @Model.Recipe.Instructions[i].Name
                                @Html.HiddenFor(m => m.Recipe.Instructions[i].Name)
                            </td>
                        </tr>
                    }
                }
            </tbody>
        </table>
    </div>
</div>
 <script type="text/javascript">
     $(document).ready(function() {
             $('#sortable').sortable({
                 update : function(event, ui) { 
                     $('td.order').each(function(index) {
                        var order = index + 1;
                        $(this).find('span').text(order);
                        $(this).find('.Number').val(order);
                     });
                 }
             });
     });
 </script

编辑:
添加
instructionList.Sort((s1, s2) => s1.Number.CompareTo(s2.Number));

到 RecipeController.cs。剩下的要归功于斯蒂芬·穆克。

食谱 Controller .cs
public ActionResult Create(NewRecipeViewModel viewModel, string command)
{

//...more code...

    var instructionList = new List<Instruction>();

    if (viewModel.Recipe.Instructions != null)
    {
        for (int i = 0; i < viewModel.Recipe.Instructions.Count; i++)
        {
            var instruction = new Instruction
            {
                Id = viewModel.Recipe.Instructions[i].Id,
                Name = viewModel.Recipe.Instructions[i].Name,
                Number = viewModel.Recipe.Instructions[i].Number

            };
            instructionList.Add(instruction);
        }
        instructionList.Sort((s1, s2) => s1.Number.CompareTo(s2.Number));
    }

//...more code...
}

新建.cshtml
 @* More code *@
 <td class="order">
      <span>@Model.Recipe.Instructions[i].Number</span>
      @Html.HiddenFor(m => m.Recipe.Instructions[i].Number, new {@class = "Number"})
 </td>

 @* More code *@    

 <script type="text/javascript">
     $(document).ready(function() {
             $('#sortable').sortable({
                 update : function(event, ui) { 
                     $('td.order').each(function(index) {
                        var order = index + 1;
                        $(this).find('span').text(order);
                        $(this).find('.Number').val(order);
                     });
                 }
             });
     });
 </script

最佳答案

您在 update 中的选择器函数不正确,将返回 undefined (您缺少 # (id 选择器),无论如何 $ 创建了一个 jQuery 对象,因此它将是 .val(...) ,而不是 value=...

但是使用 $('#Number').val(index + 1)将无法正常工作,因为它只会用 id="Number". Duplicate 更新第一个元素id` 属性是无效的 html。

请改用类名和相对选择器。将html更改为

<td class="order">
    <span>@Model.Recipe.Instructions[i].Number</span>
    @Html.HiddenFor(m => m.Recipe.Instructions[i].Number, new { @class = "Number"})
</td>

然后脚本
$('#sortable').sortable({
    update : function(event, ui) { 
        $('td.order').each(function(index) {
            var order = index + 1;
            $(this).find('span').text(order );
            $(this).find('.Number').val(order );
        });
    }
});

关于c# - 可排序、可拖动、可排序的表 + mvc 未正确更新顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52597650/

相关文章:

c# - JPEG 解压缩在 Windows 体系结构中不一致

c# - GCHandle.Free() 是否只是释放句柄?

css - 无法编辑或删除CSS文件。 (ASP.NET MVC)

asp.net - 在 ASP.Net 4 中映射到 wwwroot?

jquery - 带有 jQ​​uery UI 1.8.2 的可排序 + 嵌套列表

c# - 部分类和数据访问代码

c# - 如何验证字符串以仅允许其中包含字母数字字符?

c# - 路由添加静态段,让分页更友好asp.net core

jquery - 选择所有 (Ctrl+a) 键盘按钮不适用于 HTML5 可排序内的输入字段

AngularJS/UI ui-sortable 没有独立的作用域?