ビューからコントローラーに日付を渡すと、コントローラーからビューへのこれらの2つの日付の間のレコードの数が取得されます。複数のレコードがフェッチされるため、IEnumerable を使用してレコードのリストを表示できるようにします。ただし、IEnumerable を使用している間は、選択した日付をビューから渡してコントローラーに渡すことができません。誰でも理由を説明できますか?
これは私のコードです:
表示: Index.aspx
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<IEnumerable<ApricaCRMEvent.Models.CRM.DatabaseEntities.CRM_Doctor_Request>>" %>
<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
Index
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<link rel="stylesheet" href="../../jquery-ui-1.8.17.custom/development-bundle/themes/base/jquery.ui.all.css">
<script src="../../jquery-ui-1.8.17.custom/development-bundle/jquery-1.7.1.js"></script>
<script src="../../jquery-ui-1.8.17.custom/development-bundle/ui/jquery.ui.core.js"></script>
<script src="../../jquery-ui-1.8.17.custom/development-bundle/ui/jquery.ui.widget.js"></script>
<script src="../../jquery-ui-1.8.17.custom/development-bundle/ui/jquery.ui.datepicker.js"></script>
<link rel="stylesheet" href="../../jquery-ui-1.8.17.custom/development-bundle/demos/demos.css">
<script>
function PassValue() {
var todate = document.getElementById("Date_Modified");
var fromdate = document.getElementById("Date_Created");
todate.value = document.getElementById("txtToDate").value;
fromdate.value = document.getElementById("txtFromDate").value;
}
$(function () {
$("#txtToDate").datepicker({
altField: "#alternate",
altFormat: "DD, d MM, yy"
});
$("#txtFromDate").datepicker({
altField: "#alternate",
altFormat: "DD, d MM, yy"
});
});
</script>
<div>
<h2>Search by Date</h2>
<% using (Html.BeginForm())
{ %>
<%: Html.ValidationSummary(true, "Profile Updation was unsuccessful. Please correct the errors and try again.") %>
<%= Html.HiddenFor(model=>model.Date_Created) %>
<%= Html.HiddenFor(model=>model.Date_Modified) %>
<table>
<tr>
<td>Enter From Date</td>
<td><input type="text" id="txtFromDate"></td>
<td>Enter To Date</td>
<td><input type="text" id="txtToDate"></td>
<td><input type="submit" name="btnSearchDate" value="Search" onclick="PassValue()" /></td>
</tr>
</table>
<% } %>
</div>
<div id="showtable">
<table>
<tr>
<th>
Request_For_Id
</th>
<th>
Territory
</th>
<th>
Estimated_Amount
</th>
<th>
Actual_Amount
</th>
<th>
Date_Created
</th>
<th>
Compute_CRM_State
</th>
<th>
Compute_Event_Type
</th>
</tr>
<% foreach (var item in Model)
{ %>
<tr>
<td>
<%: Html.DisplayFor(modelItem => item.Request_For_Id)%>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Territory)%>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Estimated_Amount)%>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Actual_Amount)%>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Date_Created)%>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Compute_CRM_State)%>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Compute_Event_Type)%>
</td>
</tr>
<%} %>
</table>
</div>
</asp:Content>
コントローラ
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using ApricaCRMEvent.Models.CRM.DatabaseEntities;
using ApricaCRMEvent.Models.CRM.DataLayer;
namespace ApricaCRMEvent.Controllers.CRM
{
public class SearchDateWiseController : Controller
{
//
// GET: /SearchDateWise/
CRM_Doctor_Request dateObj = new CRM_Doctor_Request();
public ActionResult Index()
{
return View();
}
[HttpPost]
public ActionResult Index(CRM_Doctor_Request model)
{
return View(SearchMDLNoDL.getDateWiseDetails(model.Date_Created,model.Date_Modified).ToList());
}
}
}
コンパイルエラーを示すIEnumerableの使用中
Line 49: <%: Html.ValidationSummary(true, "Profile Updation was unsuccessful. Please correct the errors and try again.") %>
Line 50:
Line 51: **<%= Html.HiddenFor(model=>model.Date_Created) %>
Line 52: <%= Html.HiddenFor(model=>model.Date_Modified) %>**
Line 53: <table>
コンパイラ エラー メッセージ: CS1061: 'System.Collections.Generic.IEnumerable' には 'Date_Created' の定義が含まれておらず、タイプ 'System.Collections.Generic.IEnumerable' の最初の引数を受け入れる拡張メソッド 'Date_Created' が見つかりませんでした ( using ディレクティブまたはアセンブリ参照がありませんか?)