在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
许多时候我们会遇到如下场景 在写一个编辑数据的页面时,我们通常会写如下代码 />
由前篇我们所讲的Helper演化,我们思考,对于这种代码我们是不是也可以用一个Helper来自动绑定数据呢 这当然是可以的,ASP.NET MVC提供了一个HtmlHelper用于生成有数据绑定的Html标签。 1.ActionLink其中最常用的就是Html.ActionLink 1.1基本的使用方式)%>
在UrlRouting规则为默认规则的情况下,它生成的HTML代码为 >
ActionLink中的三个参数分别为
其中Controller可以省略,省略时指向同一Controller下的Action。 1.2ActionLink中QueryString与Html属性设置 1: 带有QueryString的写法
null)%>
new { page=1 })%>
4: 有其它Html属性的写法
})%>
})%>
7: QueryString与Html属性同时存在
})%>
})%>
其生成结果为: 1: 带有QueryString的写法
>
>
4: 有其它Html属性的写法
>
>
7: QueryString与Html属性同时存在
>
>
这样就可以使用ActionLink生成近乎所有的地址连接了。 注意,如果连接中不涉及到action及controller就没有必要使用ActionLink,而是直接写HTML代码就可以了,例如 >
>
2.RouteLink2.1与ActionLinkRouteLink与ActionLink相差无几,只是它的地址是由Route生成拿上面的例子 )%>
来说,如果用RouteLink来写就是 })%>
而带上QueryString以及Html属性的ActionLink })%>
就可以这样来写 })%>
其实就是用一个新建立的RouteValueDictionary的对象(new{}所实例化的对象将会等价转换为RouteValueDictionary)来替原来的Action,Controller字符串的单独指定。 2.2RouteLink使用Route规则除了这些协同的用法,RouteLink还支持使用Route规则名来创建连接 例如我们在Global.asax文件中添加一个Route规则 1: routes.MapRoute(
,//这是规则名
,//url
}
5: );
那么我们就可以使用这个Route规则 new { })%>
new { page = 1 })%>
})%>
来生成如下的HTML: >
>
>
3.表单很多情况下是要生成表单元素的,正如文章开始所述,修改一个内容的情况下,我们可能要将数据与表单绑定。 3.1生成Form我们当然可以使用纯的Html代码或UrlHelper来生成一个Form。 如 >
>
>
>
但是因为是在HTML的属性中,所以还是难以维护,幸好ASP.NET MVC为我们提供了一个Helper,我们可以通过以下两种方式生成一个Form: ,FormMethod.Post)){%>
2: 表单内容
3: <%} %>
//注意这里没有=输出%>
5: 表单内容
6: <%Html.EndForm(); %>
BeginForm方法类似于ActionLink的调用方式,所以ASP.NET MVC还提供了BeginRouteForm这种方法。 当然这里我们也可以使用new{}来为form的action增加querystring或HTML属性,方法与前面介绍的大同小异,参见方法列表即可。
3.2表单元素ASP.NET MVC提供了多种表单元素的Helper。 其中包括:TextBox(类似input type=text,下面类似)、TextArea、DropDownList(select)、CheckBoxHidden、ListBox、Password、RadionButton。 注意:因为<input type=”submit” />一般情况下是不会绑定数据的所以ASP.NET MVC并未提供此Helper(曾经提供过在preview2之前)。 如果我们想提供一个input type=text 它的name为t1则以下代码: ) %>
3.3表单元素绑定如果我们想要让上文中的t1初始时就有一个值,比如 “重典”那么我们可以按以下方式 ) %>
如果数据是从数据库中读取,即得到数据是从Action中获取的,那么我们可以在Action中使用ViewData传递 Action: ;
View: ]) %>
以上方法看似简单,其实ASP.NET MVC为我们提供了更为简便的绑定方式---只要保证ViewData的Key与Helper所生成元素的name保持一致就可以自动绑定: Action: ;
View: ) %>
这样就可以自动绑定了 3.4列表数据显示与绑定像TextBox这种值单一的数据比较容易,但是存在的数据比较多的DropDownList或ListBox应该怎么绑定数据及初始化值呢,我们来看看下面的例子: Action: new SelectList(
/*列表内容可以是数组*/
/*默认值,可以是从数据库读出的*/
4: );
View: )%>
这样就可以将列表内容、默认值、以及表单元素三者绑定在一起了。 而我们的列表内容并不是任何情况下都是数组的,大多情况下还是Key-Value对居多。 我们可以使用以下方式: new List<SelectListItem>
2: {
},
},
5: };
new SelectList(
/*列表内容可以是数组*/
/*默认值,可以是从数据库读出的*/
9: );
|
请发表评论