2016-09-21 93 views
0

我开发了一个模块,它工作正常。我有几个文本框并提交按钮。提交文本框值时,我将比较那些与数据库值并返回结果和显示。我也用过分页。这是我的行动方法。Mvc4在View中显示模型属性

[HttpGet] 
     public ActionResult Index(int? clientId, DateTime? dateofAction, int? doc_typeid, string employeeID,string citizenId,int? currentFilter, DateTime? filterdateTime,int? filterdocType,string filteredemployeeID,string filteredcitizenId,int? page) 
     { 
      logDetailsEnumeration model = new logDetailsEnumeration(); 
      DB_KYC3Entities db = new DB_KYC3Entities(); 
      var docTypes = from c in db.tm_doc_type select c; 
      if (clientId != null) 
      { 
       page = 1; 
      } 
      else 
      { 
       clientId = currentFilter; 
      } 
      if(dateofAction!=null) 
      { 
       page = 1; 
      } 
      else 
      { 
       dateofAction = filterdateTime; 
      } 
      if(doc_typeid != null) 
      { 
       page = 1; 
      } 
      else 
      { 
       doc_typeid = filterdocType; 

      } 
      if(employeeID!=null) 
      { 
       page = 1; 
      } 
      else 
      { 
       employeeID = filteredemployeeID; 
      } 
      if(citizenId!=null) 
      { 
       page = 1; 
      } 
      else 
      { 
       citizenId = filteredcitizenId; 
      } 

      ViewBag.CurrentFilter = clientId; 
      ViewBag.filterdateTime = dateofAction; 
      int pageSize = 8; 
      int pageNumber = (page ?? 1); 
      VerificationLogBAL obj = new VerificationLogBAL(); 
      int docType = obj.GetDocDetails(doc_typeid?? default(int)); 
      List<logDetails> logDetails = obj.getlogDetails(clientId?? default(int), dateofAction??DateTime.Now, docType, employeeID, citizenId); 
      IPagedList<logDetails> pagedLog = logDetails.ToPagedList(pageNumber, pageSize); 
      model = new logDetailsEnumeration() 
      { 
       doc_typeid= doc_typeid, 
       Count=logDetails.Count, 
       employeeID = employeeID, 
       citizenId= citizenId, 
       logDetails = pagedLog, 
       doctype_name=new SelectList(docTypes, "doc_typeid", "doctype_name") 
      }; 
      return View("Index",model); 
      } 
     } 

这是查看

<div class="forms"> 
    @using (Html.BeginForm("Index", "VerificationLog", FormMethod.Get)) 
    { 
     @Html.AntiForgeryToken() 
     @Html.ValidationSummary(true) 
     <div class="message"></div> 

     <div class="loginUsernamePassword"> 
      <i class="fa fa-user"></i> 
      <table width="100%" border="0" cellspacing="0" cellpadding="0" class="dataTable tableHover"> 
       <tr> 
        <th width="8%" scope="col">Client ID</th> 
        <th width="20%" scope="col"> 
         <div class="form-box form-box-default"> 

          @Html.TextBoxFor(x=>x.clientId, ViewBag.CurrentFilter as string, new { @id = "clientId", @placeholder = "Client ID", @class = "form-control", @maxlength = 20 }) 

         </div> 
        </th> 
        <th width="10%" scope="col">Date Of Action</th> 
        <th width="20%" scope="col"> 
         <div class="form-box form-box-default"> 
         @Html.TextBoxFor(x=>x.dateofAction, ViewBag.filterdateTime as string, new { @id = "dateofAction", @placeholder = "Date Of Action", @class = "txtBox form-control calender validate[required]" }) 
          @*@Html.TextBox("dateofAction", ViewBag.filterdateTime as string, new { @id = "dateofAction", @placeholder = "Date Of Action", @class = "txtBox form-control calender validate[required]" })*@ 


         </div> 
        </th> 
        <th width="15%" scope="col">Type Of Document</th> 
        <th width="17%" scope="col"> 
         <div class="form-box form-box-default"> 
          @*@Html.TextBox("typeofDocument", ViewBag.filterdateTime as string, new { @id = "typeofDocument", @placeholder = "Type Of Document", @class = "form-control", @maxlength = 20 })*@ 
          @Html.DropDownListFor(x=>x.doc_typeid,Model.doctype_name,"Select",new { @class = "form-control" }) 

               </div> 
        </th> 
       </tr> 
       <tr> 
        <th width="15%" scope="col">Employee ID</th> 
        <th width="17%" scope="col"> 
         <div class="form-box form-box-default"> 
          @Html.TextBoxFor(x=>x.employeeID, Model.employeeID, new { @id = "employeeID", @placeholder = "Employee ID", @class = "form-control", @maxlength = 20 }) 

         </div> 
        </th> 
        <th width="15%" scope="col">Citizen ID</th> 
        <th width="17%" scope="col"> 
         <div class="form-box form-box-default"> 
          @Html.TextBoxFor(x=>x.citizenId, Model.citizenId, new { @id = "citizenId", @placeholder = "Citizen ID", @class = "form-control", @maxlength = 20 }) 


         </div> 
        </th> 
        <th width="10%" scope="col" colspan="2"> 
         <input type="submit" value="Search" class="btn btn-primary btn-cons search" /> 
       </tr> 
      </table> 

      </div> 
      } 

     </div> 

     @if (Model != null && Model.logDetails.Count != 0) 
     { 
      <br /> 
      <h2>Verification Log</h2> 
      <br /> 
      <div id="GridDetails"> 
       <table width="100%" border="0" cellspacing="0" cellpadding="0" class="dataTable tableHover"> 
        <tr> 
         <th>Label</th> 
         <th>Value</th> 
         <th>UpdatedOn</th> 
         <th>UpdatedBy</th> 
         <th>UpdatedStatus</th> 
         <th>RejectComment</th> 
        </tr> 
        @foreach (var group in Model.logDetails) 
        { 
         <tr> 
          <td>@group.contentLabel</td> 
          <td>@group.contentValue</td> 
          <td>@group.updatedOn</td> 
          <td>@group.updatedBy</td> 
          <td>@group.updatedStatus</td> 
          <td>@group.rejectComment</td> 
         </tr> 

        } 
       </table> 

       @Html.PagedListPager(Model.logDetails, page => Url.Action("Index", 
new { page, currentFilter = ViewBag.CurrentFilter, filterdateTime=ViewBag.filterdateTime, filterdocType= Model.doc_typeid, filteredemployeeID = Model.employeeID, filteredcitizenId = Model.citizenId })) 
       Page @(Model.logDetails.PageCount < Model.logDetails.PageNumber ? 0 : Model.logDetails.PageNumber) of @Model.logDetails.PageCount 
      </div> 
     } 

上面的代码工作正常。我有一些困难。内部行动方法我有模型。在模型中我有Count = logDetails.Count。计数将保存返回的行数。当第一次加载页面时,计数值将为0,当数据库中没有相应的匹配数据时,计数值也将为0.我想显示如下所示的消息。

var records = @Html.Raw(Model.Count); 
      if(records==0) 
      { 
       fun_toastr_notify('success','No Records Found'); 
      } 

它也可以工作,但它也会在页面加载第一次(计数为零)时弹出消息。我可以知道我该如何避免这种情况?提前致谢。

+0

您可以使用Viewbag或Viewdata并为其设置计数值。如果viewbag为null,那么它是第一个请求。当它来自你的动作时,将它设置为计数,然后你可以在那里进行比较。 –

回答

0

你有没有试过类似的东西?这取决于搜索参数或任何你必须区分是否是第一次(代码已经写在飞行中,未测试)

<script type="javascript/text"> 
     document.ready(function(){ 
      @if (Model.logDetails.Count != 0) 
      { 
       fun_toastr_notify('success','No Records Found'); 
      } 
     }; 
</script> 
+0

谢谢。尝试但没有运气。 –

+0

当第一次加载页面时,当db中没有相应的数据时,Model.logDetails.Count将为零,那么Model.logDetails.Count也将为零。 –

0

首次传递一个viewbag.isfirsttime =真。 比代码

<script> 

    @{ 
     var count = !ViewBag.IsFirstTime ? Model.Count : -1; 
    }; 
    var records = @count; 
    if (records == 0) { 
     fun_toastr_notify('success', 'No Records Found'); 
    } 
</script> 

这将工作肯定。快乐编码!

+0

谢谢。不,它不起作用 –

+0

@NiranjanGodbole你怎么用它?请分享代码 –

+0

谢谢。和你上面发布的一样。 –