下拉列表只是检索对象并在Ajax文本框中动态显示

时间:2016-10-06 20:42:02

标签: sql asp.net ajax drop-down-menu asp.net-ajax

所以我开始作为一个新的ASP开发人员(已经使用Java了一点,但现在项目需要ASP),所以我的无知稍微有点:(。

我要做的是从我在SQL SERVER中获得的表创建一个动态下拉列表,并根据您在列表中选择的内容显示txt编辑器上的信息(理论上不应该这么难,但是因为我刚开始,它似乎并不那么容易)。我为它创建了实体,它的数据以及它的业务逻辑和互连(它已经从数据库读取和检索,但只是一个列表)。这就是我所做的一切。

Entity.Messages

    public class Messages
    {
        public int id { get; set; }

        public string title { get; set; }

        public string subject { get; set; }
        public string body { get; set; }
        public string createdBy { get; set; }


        public Messages()
        {
            id = 0;
            title = "";
            subject = "";
            body = "";
            createdBy = "";
        }

        public Messages(int idMessages)
        {
            idMessages = id;
            title = "";
            subject = "";
            body = "";
            createdBy = "";
        }
    }
}

Data.Messages

public class Messages : Data
{

    public Messages() : base()
        {

        }

    public List<Entity.Messages> GetAll()
    {
        List<Entity.Messages> message = new List<Entity.Messages>();
        //SQL Command para llamar el stored procedure
        SqlCommand comando = new SqlCommand("dbo.[Messages_GetAll]", base.Db);
        //Ejecuta consulta
        DataTable dtItem = base.Execute(comando);
        //Transforma el Datatable en una lista de proyectos.
        foreach (DataRow dr in dtItem.Rows)
            message.Add(GetFromDataRow(dr));

        return message;
    }

    public Entity.Messages GetById(int id)
    {
        Entity.Messages m = new Entity.Messages();
        //SQL Command para llamar el stored procedure
        SqlCommand comando = new SqlCommand("dbo.[Messages_GetById]", base.Db);
        //parametros del store procedure
        SqlParameter spKey = new SqlParameter("@Id", System.Data.SqlDbType.Int);
        spKey.Value = id;
        comando.Parameters.Add(spKey);
        //Ejecuta consulta
        DataTable dt = base.Execute(comando);
        if (dt.Rows.Count > 0)
            m = GetFromDataRow(dt.Rows[0]);
        return m;
    }

    private ASF.HC.JobApplication.Entity.Messages GetFromDataRow(DataRow dr)
    {
        Entity.Messages m = new Entity.Messages();
        m.id = dr["Id"] == DBNull.Value ? -1 : int.Parse(dr["Id"].ToString());
        m.title = dr["Title"] == DBNull.Value ? "" : dr["Title"].ToString();
        m.subject = dr["Subject"] == DBNull.Value ? "" : dr["Subject"].ToString();
        m.body = dr["Body"] == DBNull.Value ? "" : dr["Body"].ToString();
        m.createdBy = dr["createdBy"] == DBNull.Value ? "" : dr["createdBy"].ToString();
        return m;
    }
}

BO.Messages

public class Messages
    {

        public Entity.Messages GetByID(int id)
        {
            Data.Messages oMessage = new Data.Messages();
            return oMessage.GetById(id);
        }
        public List<Entity.Messages> GetAll()
        {
            Data.Messages oMessage = new Data.Messages();
            return oMessage.GetAll();
        }

在我试图显示它的地方,我看到DropDownList,我看到列表中有对象,但我想显示的是标题。

MEssage.aspx

<%@ Page Title="" Language="C#" MasterPageFile="~/Site.Master" AutoEventWireup="true" CodeBehind="Messages.aspx.cs" Inherits="ASF.HC.JobApplication.Admin.Messages" %>
<%@ Register assembly="AjaxControlToolkit" namespace="AjaxControlToolkit" tagprefix="ajaxToolkit" %>

<asp:Content ID="Content1" ContentPlaceHolderID="HeadContent" runat="server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
    <h2>Messages</h2>    
    <asp:ScriptManager ID="ScriptManager2" runat="server"></asp:ScriptManager>
    <legend>Pick the template to use:</legend>
    <asp:dropdownlist id ="ddlTemplate" runat ="server" Height="38px" Width="397px">
                  <asp:listitem value ="1"> Juan Valdez </asp:listitem >
                  <asp:listitem Value ="2"> Querido bebe</asp:listitem>
                  </asp:dropdownlist >     
    <p>&nbsp;</p>
                <asp:TextBox ID ="txtDetails" runat="server" Width="600px" Height="300px" Visible="true" ></asp:TextBox>
            <ajaxToolkit:HtmlEditorExtender ID="TextBox1_HtmlEditorExtender" runat="server" TargetControlID="txtDetails" 
                EnableSanitization="false" DisplaySourceTab="true" >
            </ajaxToolkit:HtmlEditorExtender>
</asp:Content>

Messages.aspx.cs

    public partial class Messages : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            loadList();
        }

        public void loadList()
        {
            BO.Messages template = new BO.Messages();
            ddlTemplate.DataSource = template.GetAll();
            ddlTemplate.DataBind();
        }
    }
}

我试图一步一步走,但首先我想看到的是价值,而不是对象,并根据我选择看到Ajax上文本字段显示的Body字段。但首先,最重要的是,在下拉列表中显示标题字段:(

编辑:所以我要显示标题而不是所有对象。但是现在,你们一旦选择了标题就知道了吗,将它显示在ajax的文本中?像动态?任何一点都将不胜感激。

非常感谢任何帮助或指针。

谢谢!

1 个答案:

答案 0 :(得分:0)

显然,我所需要的只是映射datavalue和datatext字段。