EditorFor 忽略 tabindex。你如何设置tabindex?

Rob*_*her 5 asp.net-mvc html-helper tabindex editorfor asp.net-mvc-2

tabindex 的使用似乎只适用于像 Textboxfor 这样的 htmlhelpers 而不是 EditorFor

例如;

<%: Html.TextBoxFor(model => Model.MyItem, new { @tabindex = "3" })%>
Run Code Online (Sandbox Code Playgroud)

产生一个 tabindex 值。

但是,如果您使用;

<%: Html.EditorFor(model => Model.MyItem, new { @tabindex = "3" })%>
Run Code Online (Sandbox Code Playgroud)

那么结果就是控件按预期创建了,但是缺少tabindex。

那么......如何为给定的EditorFor控件设置tabindex?

Rob*_*her 3

我遇到的主要问题是我需要创建一个 EditorFor 类型机制,以便像货币一样格式化小数(我们的系统有多种货币,所以“C”不合适),让选项卡索引工作并允许系统维护标准验证。

我已经成功地使用以下方法实现了这一点。通过创建我自己的自定义编辑器控件。

在项目的 Views/Shared/EditorTemplates 目录中创建一个文件(我的文件名为decimal.ascx)。

 <%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<decimal?>" %>
 <% int intTabindex = 0;
   decimal myVal = 0;

   string strModelValue = "";
   if (Model != null)
   {
       myVal = (decimal)Model;
       strModelValue = myVal.ToString("#.00");
   }
   else
       strModelValue = "";



   if (ViewData["tabindex"] != null)
   {
       intTabindex = (int)ViewData["tabindex"];
   }
 %>
 <%: Html.TextBox("", strModelValue, new { @tabindex = intTabindex })%>
Run Code Online (Sandbox Code Playgroud)

本质上,这段代码只是覆盖了通常在“十进制”EditorFor 方法中显示的内容;

<%: Html.TextBox("", Model.ToString("#.00"), new { @tabindex = intTabindex }) %>
Run Code Online (Sandbox Code Playgroud)

模板。

我的调用代码现在如下:

<%: Html.EditorFor(model => Model.MyItem, new { tabindex = 5 })%>
Run Code Online (Sandbox Code Playgroud)

结果是页面上的以下代码。

<input id="Model_MyItem" name="Model.MyItem" tabindex="5" type="text" value="12.33" />
Run Code Online (Sandbox Code Playgroud)

这正是我所需要的。

虽然这仅适用于我的特定情况,但我鼓励任何想要解决此问题的人首先尝试为该任务使用自定义控件,因为它可能会为您节省大量时间。

当然,如果可以在代码中创建所需的特定类型的控件并围绕该控件调整结果。

例如; 我们可以简单地在调用中添加另一个项目来确定文本格式。

new {tabindex = 12, numberformat=2}
Run Code Online (Sandbox Code Playgroud)

然后只需为所有格式创建一个处理程序即可。