2012-04-20 48 views
10

一個datepicker在我MVC3剃鬚刀的網頁我有一個日期字段如何獲得Html.Editorfor

@Html.EditorFor(model => model.Member.Dob) 

下面給出的是我試圖獲得場出生之日起,日期選擇器的代碼。

<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script> 
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script> 
<link href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/themes/base/jquery-ui.css" rel="stylesheet" type="text/css"/> 
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.min.js"></script> 
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/jquery-ui.min.js"></script> 
<script type="text/javascript"> 
     $(document).ready(function() { 
      debugger; 
      $("#Member_Dob").datepicker(); 
     }); 
    </script> 

但是當我運行此頁我得到錯誤

Microsoft JScript runtime error: Object doesn't support property or method 'datepicker' 

請幫我找到一種方法,日期選擇器添加到我的網頁

+0

HTML,請... – xandercoded 2012-04-20 18:00:43

回答

19

你需要創建一個EditorTemplate您Views \ Shared \ EditorTemplate文件夾。將其命名爲DateTime.cshtml。看起來應該像下面這樣:

@model System.DateTime? 
<div class="editor-label"> 
    @Html.Label("") 
</div> 
<div class="editor-field"> 
    @Html.TextBox("", String.Format("{0:MM/dd/yyyy}",(Model == DateTime.MinValue)? null : Model), new { @class="text"}) 
</div> 

<script type="text/javascript"> 
    $(document).ready(function() { 
     $("#@ViewData.ModelMetadata.PropertyName").datepicker({ 
      changeMonth: true, 
      changeYear: true, 
      dateFormat: 'mm/dd/yy', 
      gotoCurrent: true 
     }); 
    }); 
</script> 

如下使用它:

@Html.EditorFor(model => model.Member.Dob) 
+0

可以請你告訴我如何在我的視圖中渲染datetime.cshtml非常感謝你 – Ammar 2015-03-10 06:59:39

+1

如果使用'@ Html.IdForModel()'而不是'@ ViewData.ModelMetadata.PropertyName',它將在嵌套屬性上工作。參見:http://stackoverflow.com/questions/15654716/how-do-i-get-the-the-fully-qualified-member-name-in-an-editortemplate – 2015-04-14 11:51:57