заполнение выпадающего из базы данных - PullRequest
1 голос
/ 03 сентября 2011

Итак, я пишу простой макет веб-сайта (мой первый) и пытаюсь заполнить список из таблицы базы данных.

В моем контроллере у меня есть;

public void patientInit()
    {
        hospitalSQLEntities db = new hospitalSQLEntities();
        ViewData["bloodtypeList"] = db.bloodtypes.ToList();
        ViewData["doctorno"] = "";
        ViewData["wardno"] = "";
        ViewData["patientid"] = "";
        ViewData["patientname"] = "";
        ViewData["address"] = "";
        ViewData["gender"] = "";
        ViewData["bloodtype"] = 0;
        ViewData["spam"] = "";
        ViewData["organs"] = "";
        ViewData["formmessage"] = "";
    }

И на моей странице я написал это

<label for="bloodtype">Blood Type:</label>
                <select name="bloodtype"  >
                            <% List<InAmberClad.Models.bloodtype> bloodtypeList = (List<InAmberClad.Models.bloodtype>) ViewData["bloodtypeList"];
                               foreach (InAmberClad.Models.bloodtype st in bloodtypeList)
                                { 
                            %>
                                <option value="<%= st.bloodcode%>" <%if (st.bloodcode==(String) ViewData["bloodtypeList"]) Response.Write("Selected"); %>>"><%Response.Write(st.meaning); %></option>
                            <%  } %>
                                <option value="0" <%if ((Int32) ViewData["bloodtype"]==0) Response.Write("Selected"); %>></option>
                </Select>

Любая помощь с этим была бы очень признательна, я застрял на несколько часов, и это становится супер разочарованием!

Редактировать: Код ошибки окружает цикл foreach, он говорит, что «исключение NullReferenceException было обработано кодом пользователя. Ссылка на объект не установлена ​​для экземпляра объекта».

Редактировать: Вот весь код моего контроллера;

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using InAmberClad.Models;

namespace InAmberClad.Controllers
{
[HandleError]
public class HomeController : Controller
{
    public ActionResult Index()
    {
        return View();
    }

    public ActionResult patiententry()
    {
        return View();
    }
    public void patientInit()
    {
        hospitalSQLEntities db = new hospitalSQLEntities();
        ViewData["bloodtypeList"] = db.bloodtypes.ToList();
        ViewData["doctorno"] = "";
        ViewData["wardno"] = "";
        ViewData["patientid"] = "";
        ViewData["patientname"] = "";
        ViewData["address"] = "";
        ViewData["gender"] = "";
        ViewData["bloodtype"] = 0;
        ViewData["spam"] = "";
        ViewData["organs"] = "";
        ViewData["formmessage"] = "";
    }

    public void patientNewButtPressed()
    {
        if (Request.Params["submitter"] == "New Patient")
        {
            ViewData["doctorno"] = "";
            ViewData["wardno"] = "";
            ViewData["patientid"] = "(System Specified)";
            ViewData["patientname"] = "";
            ViewData["address"] = "";
            ViewData["gender"] = "";
            ViewData["bloodtype"] = 0;
            ViewData["spam"] = "";
            ViewData["organs"] = "";
            ViewData["formmessage"] = "";
        }
    }

    public void patientSearchByID()
    {
    }

    public void patientSearchByName()
    {
    }

    public void patientInsert()
    {
        hospitalSQLEntities db = new hospitalSQLEntities();
        int newid = 0;
        if (db.patients.Count() == 0)
            newid = 1;
        else
            newid = db.patients.Max(u => u.patientid) + 1;
        patient newpatient = new patient();
        newpatient.patientid = newid;
        newpatient.doctorno = Request.Params["doctorno"];
        newpatient.wardno = Request.Params["wardno"];
        newpatient.patientname = Request.Params["patientname"];
        newpatient.address = Request.Params["address"];
        newpatient.gender = Request.Params["gender"];
        newpatient.bloodtype = Request.Params["bloodtype"];
        newpatient.spam = Convert.ToInt32(Request.Params["spam"]);
        newpatient.organs = Convert.ToInt32(Request.Params["organs"]);
        db.AddTopatients(newpatient);
        db.SaveChanges();
    }

    public void patientUpdate()
    {
    }

    public ActionResult hospitalSQL()
    {
        patientInit();
        if (Request.Params["submitter"] == "New Patient")
            patientNewButtPressed();
        else if (Request.Params["submitter"] == "Search")
        {
            if (Request.Params["searchpatientid"].Length > 0)
                patientSearchByID();
            else if (Request.Params["searchpatientname"].Length > 0)
                patientSearchByName();
        }
        else if (Request.Params["submitter"] == "Cancel")
            patientInit();
        else if (Request.Params["submitter"] == "Save")
        {
            if (String.Compare(Request.Params["patientid"], "(System Specified)") == 0)
                patientInsert();
            else
                patientUpdate();
        }
        return View();
    }
}

}

Ответы [ 2 ]

1 голос
/ 03 сентября 2011

Если ваше представление строго типизировано, вы можете использовать помощника:

@Html.DropDownListFor(m => m.bloodtype, Model.bloodtypelist)

Где bloodtype - это значение, а bloodtypelist - это List<T>, которое содержит все значения, заполненные из вашей БД.в вашем контроллере.

Редактировать:

Попробуйте следующее:

<select name="bloodtype">
<% foreach (var st in (List<InAmberClad.Models.bloodtype>)ViewData["bloodtypeList"]) { %>
    <option value="<%=st.bloodcode%>" <%if (st.bloodcode==(String)ViewData["bloodtypeList"]){%> selected<%}%>><%=stmeaning%></option>
<% } %>
    <option value="0" <%if ((Int32)ViewData["bloodtype"]==0){%> selected<%}%>></option>
</select>

Я предполагаю, что он передает пустой список в представление.

Редактировать:

В вашем действии до View(); добавить patientInit();

0 голосов
/ 03 сентября 2011

Ваша жизнь станет намного проще, если вы будете использовать строго типизированные представления, однако вы можете создать раскрывающийся список без них.Посмотрите на подпись для Html.DropDownList

Html.DropDownList(
    string name,
    IEnumerable<SelectListItem> selectList,
    string optionLabel,
    object htmlAttributes) 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...