#c# #mysql #asp.net
#c# #mysql #asp.net
Вопрос:
У меня возникли проблемы с работой над тем, как отображать строки таблицы в таблице данных HTML. Я хочу отобразить информацию, хранящуюся в таблице Mysql, в таблице данных HTML, используя c # в asp.net . Проблема в том, что код работает, но в таблице HTML отображается только последняя строка. пожалуйста, помогите. код следующий,
C#
protected void ListOfEmployee()
{
List<EmployeeAccounts> empList = new List<EmployeeAccounts>();
using (MySqlConnection conn = new MySqlConnection(connectDB()))
{
conn.Open();
MySqlCommand cmd = new MySqlCommand("SELECT * FROM user", conn);
cmd.CommandType = CommandType.Text;
cmd.CommandTimeout = 0;
MySqlDataReader dr = cmd.ExecuteReader();
while (dr.Read())
{
empList.Add(new EmployeeAccounts
{
idNumber = dr["user_id"].ToString(),
uName = dr["username"].ToString(),
fName = dr["fullname"].ToString(),
uType = dr["usertype"].ToString(),
email = dr["email"].ToString(),
status = dr["status"].ToString()
});
}
dr.Close();
conn.Close();
}
}
public class EmployeeAccounts {
public string idNumber;
public string uName;
public string fName;
public string uType;
public string email;
public string status;
}
ASPX
<asp:Table ID="tblUserList" CssClass="table table-hover table-vcenter" runat="server">
<asp:TableHeaderRow TableSection="TableHeader">
<asp:TableHeaderCell >#</asp:TableHeaderCell>
<asp:TableHeaderCell >Full Name</asp:TableHeaderCell>
<asp:TableHeaderCell >Email</asp:TableHeaderCell>
<asp:TableHeaderCell >Status</asp:TableHeaderCell>
<asp:TableHeaderCell >User Type</asp:TableHeaderCell>
</asp:TableHeaderRow>
<asp:TableRow>
<asp:TableCell ID="cellID"></asp:TableCell>
<asp:TableCell ID="cellName"></asp:TableCell>
<asp:TableCell ID="cellEmail"></asp:TableCell>
<asp:TableCell CssClass="label label-table label-info" ID="cellStatus"></asp:TableCell>
<asp:TableCell ID="celluType"></asp:TableCell>
</asp:TableRow>
</asp:Table>
Комментарии:
1. Можете ли вы показать код, который у вас есть в файле code-behind (.aspx.vb)?
2. @A-A-ron я уже прикрепил код, сэр .. это был код C #.
3. Я предоставил 2-ю версию для этого, вы можете перепроверить мой ответ ниже.
Ответ №1:
List<EmployeeAccounts> lst = GetEmployeeAccounts();
var sb = new System.Text.StringBuilder();
sb.Append(@"
<table class='table table-hover table-vcenter'>
<tr>
<th>ID</th>
<th>Full Name</th>
<th>Type</th>
<th>Email</th>
<th>Status</th>
</tr>
");
if(lst.Count==0)
{
sb.Append("<tr><td colspan='5'>No record</td></tr>");
}
else
{
foreach(var acc in lst)
{
sb.Append("<tr>");
sb.AppendFormat("<td>{0}</td>", acc.idNumber);
sb.AppendFormat("<td>{0}</td>", acc.fName);
sb.AppendFormat("<td>{0}</td>", acc.uType);
sb.AppendFormat("<td>{0}</td>", acc.email);
sb.AppendFormat("<td class='label label-table label-info'>{0}</td>", acc.status);
sb.Append("</tr>");
}
}
sb.Append("</table>");
string htmlTable = sb.ToString();
добавьте заполнитель в ASP.NET страница:
<asp:PlaceHolder ID="ph1" runat="server"></asp:PlaceHolder>
затем в исходном коде продолжайте кодирование:
ph1.Controls.Add(new LiteralControl(htmlTable));
==================================
Обновление: версия 2 (25 октября 2019 г.)
List<EmployeeAccounts> lst = GetEmployeeAccounts();
var sb = new System.Text.StringBuilder();
sb.Append(@"
<table class='table table-hover table-vcenter'>
<tr>
<th>ID</th>
<th>Full Name</th>
<th>Type</th>
<th>Email</th>
<th>Status</th>
</tr>
");
if (lst.Count == 0)
{
sb.Append("<tr><td colspan='5'>No record</td></tr>");
}
else
{
foreach (var acc in lst)
{
sb.Append($@"
<tr>
<td>{acc.idNumber}</td>
<td>{acc.fName}</td>
<td>{acc.uType}</td>
<td>{acc.email}</td>
<td class='label label-table label-info'>{acc.status}</td>
</tr>
");
}
}
sb.Append("</table>");
string htmlTable = sb.ToString();