[英]How to add a dropdownlist that's dynamically populated from database to each row in datatable gridview
因此,我創建了一個功能齊全的 gridview,其中最后兩列作為從數據庫填充的下拉列表,並從中讀取/寫入。 但是我需要實現對 gridview 的搜索,所以我使用了 Datatables.net 插件,它工作得很好,但是一旦我添加了下拉列表,搜索就會被禁用。 除非我通過 javascript 添加它們,而且我在該領域的經驗還不夠多,無法自己完成。
在我切換到數據表插件之前,我曾經只是在gridview的Rowdatabound事件中附加我需要的下拉列表,如何通過javascript實現類似的東西?
這是java腳本代碼:
var TableContent = "<tr>";
if (!$("#req").length)
$("body").append("<table id='req'></table>");
else
$('#req').prepend($('<thead>').append($('.add_ADU')));
var colns = [
{ "data": "Request_ID", title: "ID", },
{ "data": "Student_ID", visible:true },
{ "data": "Type", visible:true },
{ "data": "Description", visible:true },
{ "data": "Language", visible:true },
{ "data": "PUC", visible:true },
{ "data": "Quantity", title: "Quantity" },
{ "data": "Comments", title: "Comments" },
{ "data": "Fees", title: "Fees" },
{ "data": "Date", title: "Date" },
{ "data": "Payment_Status", title: "Payment Status" },
{ "data": "Payment_Date", title: "Payment Date" },
{ "data": "Student_Name", title: "Student Name", visible:true },
{ "data": "Payment_ID",title:"Payment ID", title: "Phone" },
{ "data": "Addressed_To",title: "Addressed To", visible:true },
{ "data": "username", title:"Assigned To",visible:true },
{ "data": "status", title:"Status",visible:true }
];
var table = $('#req').DataTable({
select: true,
"columns": colns,
"order": [[ 12, "desc" ]],
"initComplete": function (settings, json) {
reset_table_page_length($(window).height());
},
});
$("#req tr").append(
'<select id="assign"' +
'<option value="Paid">him</option>' +
'<option value="NotPaid">her</option>' +
'</select>'
)
$("#req_filter").prepend(
'<select id="inp-sel-status-fltr" class="table-toolbar-inp">' +
'<option value="Paid">Paid</option>' +
'<option value="NotPaid">Not Paid</option>'+
'</select>'
)
$("#inp-sel-status-fltr").change(function myfunction() {
filter_table_by_status($(this).val());
});
function filter_table_by_status(val) {
table.column(10).search(val);
table.draw();
}
盡管很可悲,但這就是我實現我想要實現的目標的程度:
$("#req tr").append(
'<select id="assign"' +
'<option value="Paid">him</option>' +
'<option value="NotPaid">her</option>' +
'</select>')
這是 gridview 的 HTML 代碼:
<div class="container">
<asp:GridView BorderWidth="0" CssClass="stripe compact order-column row-border" runat="server" AutoGenerateColumns="true" ID="req" OnRowDataBound="req_RowDataBound" ClientIDMode="Static" Style="width: 100% !important">
<HeaderStyle CssClass="add_ADU" />
</asp:GridView>
在后面的代碼中,我只會附加下拉列表,然后查詢我需要的數據並使用以下代碼填充它們:
protected void req_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
DataTable table = new DataTable();
var openCloseddl = e.Row.FindControl("openCloseddl") as DropDownList;
var assignddl = e.Row.FindControl("assignToddl") as DropDownList;
assignddl.DataMember = "username";
assignddl.DataValueField = "username";
assignddl.DataSource = table;
//get the values of the conditions that define which staff
var request_id = e.Row.Cells[0].Text;
var type = e.Row.Cells[3].Text;
var description = e.Row.Cells[4].Text;
var puc = e.Row.Cells[6].Text;
var quantity = e.Row.Cells[7].Text;
//fetch which staff member it's assigned to if exists.
SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["studentOrderUpload"].ConnectionString);
SqlCommand comm = new SqlCommand("SELECT username from request_status WHERE request_id = @request_id and type = @type and description = @description and puc = @puc and quantity = @quantity", conn);
comm.Parameters.AddWithValue("@request_id", request_id);
comm.Parameters.AddWithValue("@type", type);
comm.Parameters.AddWithValue("@description", description);
comm.Parameters.AddWithValue("@puc", puc);
comm.Parameters.AddWithValue("@quantity", quantity);
try
{
conn.Open();
object result = comm.ExecuteScalar();
string resultText = (result == null ? "" : result.ToString());
conn.Close();
//if it's not assigned to anyone, show every staff member.
if (resultText == "")
{
if (type.ToLower().Contains("customized"))
{
SqlCommand cmd1 = new SqlCommand("select username from staff where type = 'customized'", conn);
conn.Open();
SqlDataAdapter ad1 = new SqlDataAdapter(cmd1);
ad1.Fill(table);
conn.Close();
assignddl.DataBind();
assignddl.SelectedValue = "Scholarship";
if (openCloseddl.SelectedValue == "Open")
{
openCloseddl.Enabled = true;
}
assignddl.Items.RemoveAt(1);
}
else
{
SqlCommand cmd1 = new SqlCommand("select username from staff where type ='standard'", conn);
conn.Open();
SqlDataAdapter ad1 = new SqlDataAdapter(cmd1);
ad1.Fill(table);
conn.Close();
assignddl.DataBind();
}
assignddl.Items.Insert(0, new ListItem("Select User"));
openCloseddl.Enabled = false;
if (openCloseddl.SelectedValue == "Open" && type.ToLower().Contains("customized"))
{
openCloseddl.Enabled = true;
}
}
//if it's assigned to someone, show only the assigned staff,
else
{
if (type.ToLower().Contains("customized"))
{
SqlCommand cmd1 = new SqlCommand("select username from staff where type = 'customized'", conn);
conn.Open();
SqlDataAdapter ad1 = new SqlDataAdapter(cmd1);
ad1.Fill(table);
conn.Close();
assignddl.DataBind();
assignddl.SelectedValue = "Scholarship";
if (openCloseddl.SelectedValue == "Open")
{
openCloseddl.Enabled = true;
}
assignddl.Items.RemoveAt(1);
}
else
{
SqlCommand cmd1 = new SqlCommand("select username from staff where type = 'standard'", conn);
conn.Open();
SqlDataAdapter ad1 = new SqlDataAdapter(cmd1);
ad1.Fill(table);
conn.Close();
assignddl.DataBind();
assignddl.SelectedValue = resultText;
}
}
if (openCloseddl != null)
{
SqlCommand comm1 = new SqlCommand("SELECT status from request_status WHERE request_id = @request_id and type = @type and description = @description and puc = @puc and quantity = @quantity", conn);
comm1.Parameters.AddWithValue("@request_id", request_id);
comm1.Parameters.AddWithValue("@type", type);
comm1.Parameters.AddWithValue("@description", description);
comm1.Parameters.AddWithValue("@puc", puc);
comm1.Parameters.AddWithValue("@quantity", quantity);
conn.Open();
object result1 = comm1.ExecuteScalar();
conn.Close();
if (result1.ToString() == "Closed")
{
openCloseddl.SelectedValue = "Closed";
openCloseddl.Enabled = false;
assignddl.Enabled = false;
if ((HttpContext.Current.User.Identity.Name.Equals("DocRequestAdmin")))
{
assignddl.Enabled = true;
openCloseddl.Enabled = true;
}
}
}
}
catch (Exception ee)
{
var error = ee.Message;
conn.Close();
}
var paid = e.Row.Cells[12].Text;
if (paid.Contains("Not"))
{
assignddl.SelectedValue = "Select User";
assignddl.Enabled = false;
openCloseddl.Enabled = false;
}
}
}
在這一點上我相信這是無關緊要的,因為我正在嘗試通過 javascript 來做到這一點。
這是網格外觀的屏幕截圖,我要添加的下拉列表應存在於最后兩列“已分配給”和“狀態”中
數據表中有一個內置的渲染函數,您可以在列對象中調用它。 該函數接受 3 個參數,第一個是您在“數據”屬性中指定的屬性的值,第三個將返回整個底層對象的值。
你可以在這里閱讀它。
例如:
{
"data": "username",
title:"Assigned To",
visible:true,
render: function(data, type, row) {
//do sth here
}
}
在上面的render函數中, data參數將返回“username”屬性的值, row參數將返回底層對象所有屬性的值。
您可以使用 row 參數提供的數據將值和 id 附加到下拉列表中。 如果您的 row 參數返回一個對象數組,您可以執行 for 循環來迭代並將每個值附加到 select 元素。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.