ASP.NET MVC - 如何使用arraylist数据显示部分视图

时间:2015-11-11 22:28:56

标签: c# jquery asp.net-mvc asp.net-ajax

我希望根据所选按钮在aspx网页上显示三个不同的局部视图。那部分工作正常。但是,然后每个部分视图将从xml文件中读取单独的部分,并且还将为视图提供数据。我试图将数据作为Arraylist传递给视图,但部分视图现在不显示。在没有传递数据的情况下,部分视图正在运行。 请注意我使用的是aspx而非razor。有关如何使其工作的任何想法,以便在单击3个按钮中的任何一个时,还会显示不同的部分视图以及xml数据。提前谢谢。

RenderVOIP.aspx

$(function() {
        $('#InfoButton').on("click", function() {        
            $.get('<%= Url.Action("InfoAction", "HardwareRequisition")%>', function (data) {
                $( "#myContentView" ).html( data );
            });
            $('#NotesButton').on("click", function() {              
                $.get('<%= Url.Action("NotesAction", "HardwareRequisition")%>', function (data) {
                    $( "#myContentView" ).html( data );
                });
                $('#OrdersButton').on("click", function() {                  
                    $.get('<%= Url.Action("OrdersAction", "HardwareRequisition")%>', function (data) {
                        $( "#myContentView" ).html( data );
                    });
                });
            });
        });
    });

<input type="text" id="box" style="width: 100px;" />
      <div class="row">
                    <div class="col-lg-12" id="account-subnavigation">
                        <div class="btn-group" style=" margin-bottom:10px; margin-left:10px;">                         
                            <button class="btn btn-info" style="width:120px" id="InfoButton">Info</button>
                            <button class="btn btn-info" style="width:120px" id="NotesButton">Notes</button>
                            <button class="btn btn-info" style="width:120px" id="ordersButton">Orders</button>
                        </div>
                    </div>
                </div>

               <div class="row" id="myContentView">

                </div>

voipSubform1.ascx

<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<Products>" %>

<h2>VoIP Subform 1</h2>
 test
<fieldset id="voipdetails" class="section2">

    <table class="table table-bordered"> 
<tr> 
<th>Id</th> 
<th>Product Name</th> 
<th>Product Cost</th> 
</tr> 
<% foreach (var product in ((IEnumerable<Products>)ViewData["data"]))

{ %> 
<tr> 
<td> 
    <%: product.ProductId%>
</td> 
<td> 
<%= product.ProductName%>
</td> 
<td> 
<%= product.ProductCost%>
</td> 
</tr> 
<% } %>
</table>
 
HardwareRequisitionController.cs

public ActionResult InfoAction()
            {
                //return View("VoIPSubform1", _repository.GetForm(8));
      //          return PartialView("_MySecondPartialView");
      //          return View("RenderVOIPForm", _repository.GetForm(8));

                var filename = AppDomain.CurrentDomain.BaseDirectory + "App_Data\\" + "log\\" + "logErrors.txt";
                try
                {
                    XMLReader readXML = new XMLReader();
                    var data = readXML.ReturnListOfProducts().ToList();

                }
                catch (Exception e)
                {
                    var sw = new System.IO.StreamWriter(filename, true);
                    sw.WriteLine(DateTime.Now.ToString() + " " + e.Message + " " + e.InnerException);
                    sw.Close();
                }
               // return View(data.ToList());
                XMLReader readXML2 = new XMLReader();
                var data2 = readXML2.ReturnListOfProducts();

                var sw2 = new System.IO.StreamWriter(filename, true);
                sw2.WriteLine(DateTime.Now.ToString() + " " + data2);
                sw2.Close();

                return PartialView("_VoIPSubform1", data2);

           //     return View("_VoIPSubform1", data.ToList());
            }  

1 个答案:

答案 0 :(得分:0)

如果有人对解决方案感兴趣,我在控制器中添加了这些行并且它有效。

<meta property="og:video" content="http://s3.amazon...etc">

<meta property="og:video:secure_url" content="https://s3.amazon...etc">