Asp.net Mvc Codeplex Preview 5 第一篇 Helper的新特性

 

下载:http://www.codeplex.com/aspnet/Release/ProjectReleases.aspx?ReleaseId=16775

 

Asp.net Mvc Codeplex Preview 5Asp.net Mvc的一个过渡版本,它包含了一些新特性。

Pv5对于Helper的更改基本集中在HtmlHelper。对于简单的使用,我基本一带而过,如果朋友们有什么不明白,可以留言。

AttributeEncode提供了HtmlAttributeEncode功能

使用方法
<%= Html.AttributeEncode( " <script src=/ " j.js/ " ></script><div background='javascript:alert('');'/> " %>
编码结果
& lt;script src =& quot;j.js & quot; >& lt; / script >& lt;div background = ' javascript:alert( '' ); ' />

方法仅将引号 (")、“and”符号 (&) 和左尖括号 (<) 转换为等效的字符实体。该方法比Encode/HtmlEncode方法快得多。

 


Encode 提供了HTMLENCODE功能

 

使用方法
<%= Html.Encode( " <script src=/ " j.js/ " ></script><div background='javascript:alert('');'/> " ) %>
编码结果
& lt;script src =& quot;j.js & quot; & gt; & lt; / script & gt; & lt;div background = ' javascript:alert( '' ); ' /& gt;

RenderUserControl 改为 RenderPartial,并提供了更好的模板寻找方式

 

<% = Html.RenderUserControl( " /Views/Shared/Menu.ascx " %>
改为
<%  Html.RenderPartial( " Menu " ); %>
注意,原来的
<% = %> 改了为一句语言,有分号结束,与RenderAction统一了

验证控件

 起到了服务器端验证作用,

效果如下:

 

使用方法如下:

Model:

     public   class  MyModel
    {
        
public   int  ID {  get set ; }
        
public   string  Name {  get set ; }
    }

View:

     < h3 > 验证控件  </ h3 >
    
<% using (Html.Form( " home " " save " , FormMethod.Post)) { %>
    
<% = Html.TextBox( " ID " ) %>
    
<% = Html.ValidationMessage( " ID " , new  {style = " color:green " }) %>
    
<% = Html.TextBox( " Name " ) %>
    
<% = Html.ValidationMessage( " Name " ) %>
    
<% = Html.SubmitButton()  %>
    
<%
        }
%>
    
< div  style ="color: Red" >
        
<% = Html.ValidationSummary()  %>
    
</ div >

 Controller:

public   class  HomeController : Controller {
        
public  ActionResult Index() {//显示表单的页
            ViewData[
" Title " =   " Home Page " ;
            ViewData[
" Message " =   " Welcome to ASP.NET MVC! " ;
            
return  View();
        }
        [AcceptVerbs(
" POST " )]
        
public  ActionResult Save( int ?  ID,  string  Name)
        {//处理表单的页
            
if (ID == null )
            ViewData.ModelState.AddModelError(
" ID " , ID.ToString(),  " ID是必添项! " );
            
if  ( string .IsNullOrEmpty(Name))
                ViewData.ModelState.AddModelError(
" Name " , Name,  " Name是必添项! " );
            
if  (ViewData.ModelState.IsValid)//验证成功后做的操作
                
return  RedirectToAction( " Index " );
            
return  View( " Index " );//else
        }
        
        
public  ActionResult About() {
            
return  View();
        }
    }


 这就是PV5为我们提供了简单的验证功能了。

AntiForgeryToken

这是一个验证提交页的东西,类似ViewState

先在提交页的表单中写

<%=Html.AntiForgeryToken() %>

 生成一个类似

  < input  name ="__MVC_AntiForgeryToken"  type ="hidden"  value ="FaSCzN4P+6Hg977mdOX4z9pCKOy4vlP6whi0RGD+2L9mbTNGGx4GmN36sE4klJZf"   />

 的隐藏字段。

 拿刚才的Action为例:

        [ValidateAntiForgeryToken]
        
public  ActionResult Save( int ?  ID,  string  Name)
       

 DropDownList新加了默认项

要 <%=Html.DropDownList("请选择","CityID", new { @class = "select" })%>

如果不需要默认项留空字符串即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值