首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在表单上显示数据并异步更新表单

在表单上显示数据并异步更新表单
EN

Stack Overflow用户
提问于 2012-06-22 05:29:33
回答 1查看 461关注 0票数 0

实现这一目标的最好方法是什么?我有一个文本框,教师可以在其中输入学生ID,我希望根据输入的id显示学生信息。一旦显示了学生信息,我就有一个下拉列表,其中包含一个列表,其中列出了该学生注册的所有课程。从下拉列表中选择课程后,我希望在表单的特定部分中显示学生在表单上的进度。我该如何处理这个问题呢?这是我到目前为止所知道的:

控制器:

代码语言:javascript
运行
复制
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using Student.Models;


namespace Student.Controllers
{
    public class StudentFormController : Controller
    {
        //
        // GET: /StudentForm/

        public ActionResult Index()
        {
            return View("StudentForm");
        }

        public ActionResult DisplayStudentDetails(string StudentId)
        {
            StudentDataContext db = new StudentDataContext();
            var StudentName = (from p in db.vwStudent.Where(a => a.StudentID == StudentId)
                             group p by p.StudentName into g
                             select g.Key).FirstOrDefault();

            var StudentClassList = (from p in db.vwStudent.Where(a => a.StudentID ==          StudentId)
                             group p by p.ClassID into g
                             select g.Key).ToList();

            ViewData["StudentName"] = StudentName;
            ViewData["StudentClassList "] = StudentClassList ;

            return View("StudentForm");

        }

        public ActionResult DisplayClassDetails(string StudentId, string ClassId)
        {
            StudentDataContext db = new StudentDataContext();
            ViewData.Model = (from p in db.vwStudentProgress.Where(a => a.StudentID == StudentId && a.ClassID == ClassId);

            return View("LPForm");

        }

    }
}

视图(表单):

代码语言:javascript
运行
复制
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<dynamic>" %>

<asp:Content ID="Content3" ContentPlaceHolderID="TitleContent" runat="server">
    Student Form
</asp:Content>
<asp:Content ID="Content4" ContentPlaceHolderID="MainContent" runat="server">
<form id="form2" method="get" action="/StudentForm/DisplayStudentDetails/" runat="server">
    <div style="text-align: left; height: 202px;">
<asp:ScriptManager ID="ScriptManager2" runat="server">
</asp:ScriptManager>                
<asp:UpdatePanel ID="UpdatePanel2" runat="server">
    <ContentTemplate>
        Student Id:<input type="text" name="id" value="<%=HttpContext.Current.Request.QueryString["StudentId"]%>" /><br />                    
        Student Name:<input type="text" name="StudentName" value="<%=ViewData["ShortName"]%>" /><br />
        Classes Enrolled in:
        <select name="Classes">
            <%if (ViewData["Classes"] != null)
            {%>               
            <% foreach (int? Classes in (List<int?>)ViewData["Classes"])
            {%>                                
            <option><%=Classes%></option>                                
            <%}%>               
            <%}%>                   
    </ContentTemplate>
</asp:UpdatePanel>
    <input type="submit" value="Display Student Details"/>
</div>
</form>
</asp:Content>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-06-23 00:53:42

解决这个问题的最好方法是什么?

简单的答案是AJAX。不要试图在ASP.NET MVC应用程序中使用更新面板。使用jquery扩展ajax调用并更新页面的一部分。

从下拉列表中选择课程后,我希望在表单的特定部分中显示学生的进度。我该如何处理这个问题呢?

基本上,您应该通过jquery绑定到dropdown的change事件,并调用一个返回局部视图的操作。

使用html助手来创建文本框、表单和其他东西,并避免直接使用html元素。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11147046

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档