IBindableTemplate Antarmuka
Definisi
Penting
Beberapa informasi terkait produk prarilis yang dapat diubah secara signifikan sebelum dirilis. Microsoft tidak memberikan jaminan, tersirat maupun tersurat, sehubungan dengan informasi yang diberikan di sini.
Menyediakan cara untuk ASP.NET kontrol terikat data, seperti DetailsView dan FormView, untuk secara otomatis mengikat kontrol sumber data ASP.NET dalam bagian konten templat.
public interface class IBindableTemplate : System::Web::UI::ITemplate
public interface IBindableTemplate : System.Web.UI.ITemplate
type IBindableTemplate = interface
interface ITemplate
Public Interface IBindableTemplate
Implements ITemplate
- Turunan
- Penerapan
Contoh
Contoh kode berikut menunjukkan bagaimana FormView kontrol dapat menentukan konten templat secara deklaratif, mengikat data yang SqlDataSource disediakan oleh kontrol, serta menampilkan dan mengedit rekaman yang ada. Pengurai ASP.NET mengurai konten templat dan membuat IBindableTemplate objek pada durasi yang dapat mengikat nilai dari SqlDataSource kontrol ke area pengikatan data yang ditentukan dalam templat dengan sintaks pengikatan data satu arah ASP.NET (<%# Eval("fieldname") %>
) dan sintaks pengikatan data dua arah (<%# Bind("fieldname") %>
).
Penting
Kontrol ini memiliki kotak teks yang menerima input pengguna, yang merupakan potensi ancaman keamanan. Secara default, ASP.NET halaman Web memvalidasi bahwa input pengguna tidak menyertakan elemen skrip atau HTML. Untuk informasi selengkapnya, lihat Gambaran Umum Eksploitasi Skrip.
<%@ Page language="C#" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
void EmployeeFormView_ItemUpdating(Object sender, FormViewUpdateEventArgs e)
{
// Validate the field values entered by the user. This
// example determines whether the user left any fields
// empty. Use the NewValues property to access the new
// values entered by the user.
ArrayList emptyFieldList = ValidateFields(e.NewValues);
if (emptyFieldList.Count > 0)
{
// The user left some fields empty. Display an error message.
// Use the Keys property to retrieve the key field value.
String keyValue = e.Keys["EmployeeID"].ToString();
MessageLabel.Text = "You must enter a value for each field of record " +
keyValue + ".<br/>The following fields are missing:<br/><br/>";
// Display the missing fields.
foreach (String value in emptyFieldList)
{
// Use the OldValues property to access the original value
// of a field.
MessageLabel.Text += value + " - Original Value = " +
e.OldValues[value].ToString() + "<br />";
}
// Cancel the update operation.
e.Cancel = true;
}
else
{
// The field values passed validation. Clear the
// error message label.
MessageLabel.Text = "";
}
}
ArrayList ValidateFields(IOrderedDictionary list)
{
// Create an ArrayList object to store the
// names of any empty fields.
ArrayList emptyFieldList = new ArrayList();
// Iterate though the field values entered by
// the user and check for an empty field. Empty
// fields contain a null value.
foreach (DictionaryEntry entry in list)
{
if (entry.Value == String.Empty)
{
// Add the field name to the ArrayList object.
emptyFieldList.Add(entry.Key.ToString());
}
}
return emptyFieldList;
}
void EmployeeFormView_ModeChanging(Object sender, FormViewModeEventArgs e)
{
if (e.CancelingEdit)
{
// The user canceled the update operation.
// Clear the error message label.
MessageLabel.Text = "";
}
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>FormView Example</title>
</head>
<body>
<form id="form1" runat="server">
<h3>FormView Example</h3>
<asp:formview id="EmployeeFormView"
datasourceid="EmployeeSource"
allowpaging="true"
datakeynames="EmployeeID"
headertext="Employee Record"
emptydatatext="No employees found."
onitemupdating="EmployeeFormView_ItemUpdating"
onmodechanging="EmployeeFormView_ModeChanging"
runat="server">
<headerstyle backcolor="CornFlowerBlue"
forecolor="White"
font-size="14"
horizontalalign="Center"
wrap="false"/>
<rowstyle backcolor="LightBlue"
wrap="false"/>
<pagerstyle backcolor="CornFlowerBlue"/>
<itemtemplate>
<table>
<tr>
<td rowspan="6">
<asp:image id="EmployeeImage"
imageurl='<%# Eval("PhotoPath") %>'
alternatetext='<%# Eval("LastName") %>'
runat="server"/>
</td>
<td colspan="2">
</td>
</tr>
<tr>
<td>
<b>Name:</b>
</td>
<td>
<%# Eval("FirstName") %> <%# Eval("LastName") %>
</td>
</tr>
<tr>
<td>
<b>Title:</b>
</td>
<td>
<%# Eval("Title") %>
</td>
</tr>
<tr>
<td>
<b>Hire Date:</b>
</td>
<td>
<%# Eval("HireDate","{0:d}") %>
</td>
</tr>
<tr style="height:150; vertical-align:top">
<td>
<b>Address:</b>
</td>
<td>
<%# Eval("Address") %><br/>
<%# Eval("City") %> <%# Eval("Region") %>
<%# Eval("PostalCode") %><br/>
<%# Eval("Country") %>
</td>
</tr>
<tr>
<td colspan="2">
<asp:linkbutton id="Edit"
text="Edit"
commandname="Edit"
runat="server"/>
</td>
</tr>
</table>
</itemtemplate>
<edititemtemplate>
<table>
<tr>
<td rowspan="6">
<asp:image id="EmployeeEditImage"
imageurl='<%# Eval("PhotoPath") %>'
alternatetext='<%# Eval("LastName") %>'
runat="server"/>
</td>
<td colspan="2">
</td>
</tr>
<tr>
<td>
<b>Name:</b>
</td>
<td>
<asp:textbox id="FirstNameUpdateTextBox"
text='<%# Bind("FirstName") %>'
runat="server"/>
<asp:textbox id="LastNameUpdateTextBox"
text='<%# Bind("LastName") %>'
runat="server"/>
</td>
</tr>
<tr>
<td>
<b>Title:</b>
</td>
<td>
<asp:textbox id="TitleUpdateTextBox"
text='<%# Bind("Title") %>'
runat="server"/>
</td>
</tr>
<tr>
<td>
<b>Hire Date:</b>
</td>
<td>
<asp:textbox id="HireDateUpdateTextBox"
text='<%# Bind("HireDate", "{0:d}") %>'
runat="server"/>
</td>
</tr>
<tr style="height:150; vertical-align:top">
<td>
<b>Address:</b>
</td>
<td>
<asp:textbox id="AddressUpdateTextBox"
text='<%# Bind("Address") %>'
runat="server"/>
<br/>
<asp:textbox id="CityUpdateTextBox"
text='<%# Bind("City") %>'
runat="server"/>
<asp:textbox id="RegionUpdateTextBox"
text='<%# Bind("Region") %>'
width="40"
runat="server"/>
<asp:textbox id="PostalCodeUpdateTextBox"
text='<%# Bind("PostalCode") %>'
width="60"
runat="server"/>
<br/>
<asp:textbox id="CountryUpdateTextBox"
text='<%# Bind("Country") %>'
runat="server"/>
</td>
</tr>
<tr>
<td colspan="2">
<asp:linkbutton id="UpdateButton"
text="Update"
commandname="Update"
runat="server"/>
<asp:linkbutton id="CancelButton"
text="Cancel"
commandname="Cancel"
runat="server"/>
</td>
</tr>
</table>
</edititemtemplate>
<pagersettings position="Bottom"
mode="Numeric"/>
</asp:formview>
<br/><br/>
<asp:label id="MessageLabel"
forecolor="Red"
runat="server"/>
<!-- This example uses Microsoft SQL Server and connects -->
<!-- to the Northwind sample database. Use an ASP.NET -->
<!-- expression to retrieve the connection string value -->
<!-- from the Web.config file. -->
<asp:sqldatasource id="EmployeeSource"
selectcommand="Select [EmployeeID], [LastName], [FirstName], [Title], [Address], [City], [Region], [PostalCode], [Country], [HireDate], [PhotoPath] From [Employees]"
updatecommand="Update [Employees] Set [LastName]=@LastName, [FirstName]=@FirstName, [Title]=@Title, [Address]=@Address, [City]=@City, [Region]=@Region, [PostalCode]=@PostalCode, [Country]=@Country Where [EmployeeID]=@EmployeeID"
connectionstring="<%$ ConnectionStrings:NorthWindConnectionString%>"
runat="server"/>
</form>
</body>
</html>
<%@ Page language="VB" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
Sub EmployeeFormView_ItemUpdating(ByVal sender As Object, ByVal e As FormViewUpdateEventArgs) Handles EmployeeFormView.ItemUpdating
' Validate the field values entered by the user. This
' example determines whether the user left any fields
' empty. Use the NewValues property to access the new
' values entered by the user.
Dim emptyFieldList As ArrayList = ValidateFields(e.NewValues)
If emptyFieldList.Count > 0 Then
' The user left some fields empty. Display an error message.
' Use the Keys property to retrieve the key field value.
Dim keyValue As String = e.Keys("EmployeeID").ToString()
MessageLabel.Text = "You must enter a value for each field of record " & _
keyValue & ".<br/>The following fields are missing:<br/><br/>"
' Display the missing fields.
Dim value As String
For Each value In emptyFieldList
' Use the OldValues property to access the original value
' of a field.
MessageLabel.Text &= value & " - Original Value = " & _
e.OldValues(value).ToString() & "<br />"
Next
' Cancel the update operation.
e.Cancel = True
Else
' The field values passed validation. Clear the
' error message label.
MessageLabel.Text = ""
End If
End Sub
Function ValidateFields(ByVal list As IOrderedDictionary) As ArrayList
' Create an ArrayList object to store the
' names of any empty fields.
Dim emptyFieldList As New ArrayList()
' Iterate though the field values entered by
' the user and check for an empty field. Empty
' fields contain a null value.
Dim entry As DictionaryEntry
For Each entry In list
If entry.Value Is String.Empty Then
' Add the field name to the ArrayList object.
emptyFieldList.Add(entry.Key.ToString())
End If
Next
Return emptyFieldList
End Function
Sub EmployeeFormView_ModeChanging(ByVal sender As Object, ByVal e As FormViewModeEventArgs) Handles EmployeeFormView.ModeChanging
If e.CancelingEdit Then
' The user canceled the update operation.
' Clear the error message label.
MessageLabel.Text = ""
End If
End Sub
</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>FormView Example</title>
</head>
<body>
<form id="form1" runat="server">
<h3>FormView Example</h3>
<asp:formview id="EmployeeFormView"
datasourceid="EmployeeSource"
allowpaging="true"
datakeynames="EmployeeID"
headertext="Employee Record"
emptydatatext="No employees found."
runat="server">
<headerstyle backcolor="CornFlowerBlue"
forecolor="White"
font-size="14"
horizontalalign="Center"
wrap="false"/>
<rowstyle backcolor="LightBlue"
wrap="false"/>
<pagerstyle backcolor="CornFlowerBlue"/>
<itemtemplate>
<table>
<tr>
<td rowspan="6">
<asp:image id="EmployeeImage"
imageurl='<%# Eval("PhotoPath") %>'
alternatetext='<%# Eval("LastName") %>'
runat="server"/>
</td>
<td colspan="2">
</td>
</tr>
<tr>
<td>
<b>Name:</b>
</td>
<td>
<%# Eval("FirstName") %> <%# Eval("LastName") %>
</td>
</tr>
<tr>
<td>
<b>Title:</b>
</td>
<td>
<%# Eval("Title") %>
</td>
</tr>
<tr>
<td>
<b>Hire Date:</b>
</td>
<td>
<%# Eval("HireDate","{0:d}") %>
</td>
</tr>
<tr style="height:150; vertical-align:top">
<td>
<b>Address:</b>
</td>
<td>
<%# Eval("Address") %><br/>
<%# Eval("City") %> <%# Eval("Region") %>
<%# Eval("PostalCode") %><br/>
<%# Eval("Country") %>
</td>
</tr>
<tr>
<td colspan="2">
<asp:linkbutton id="Edit"
text="Edit"
commandname="Edit"
runat="server"/>
</td>
</tr>
</table>
</itemtemplate>
<edititemtemplate>
<table>
<tr>
<td rowspan="6">
<asp:image id="EmployeeEditImage"
imageurl='<%# Eval("PhotoPath") %>'
alternatetext='<%# Eval("LastName") %>'
runat="server"/>
</td>
<td colspan="2">
</td>
</tr>
<tr>
<td>
<b>Name:</b>
</td>
<td>
<asp:textbox id="FirstNameUpdateTextBox"
text='<%# Bind("FirstName") %>'
runat="server"/>
<asp:textbox id="LastNameUpdateTextBox"
text='<%# Bind("LastName") %>'
runat="server"/>
</td>
</tr>
<tr>
<td>
<b>Title:</b>
</td>
<td>
<asp:textbox id="TitleUpdateTextBox"
text='<%# Bind("Title") %>'
runat="server"/>
</td>
</tr>
<tr>
<td>
<b>Hire Date:</b>
</td>
<td>
<asp:textbox id="HireDateUpdateTextBox"
text='<%# Bind("HireDate", "{0:d}") %>'
runat="server"/>
</td>
</tr>
<tr style="height:150; vertical-align:top">
<td>
<b>Address:</b>
</td>
<td>
<asp:textbox id="AddressUpdateTextBox"
text='<%# Bind("Address") %>'
runat="server"/>
<br/>
<asp:textbox id="CityUpdateTextBox"
text='<%# Bind("City") %>'
runat="server"/>
<asp:textbox id="RegionUpdateTextBox"
text='<%# Bind("Region") %>'
width="40"
runat="server"/>
<asp:textbox id="PostalCodeUpdateTextBox"
text='<%# Bind("PostalCode") %>'
width="60"
runat="server"/>
<br/>
<asp:textbox id="CountryUpdateTextBox"
text='<%# Bind("Country") %>'
runat="server"/>
</td>
</tr>
<tr>
<td colspan="2">
<asp:linkbutton id="UpdateButton"
text="Update"
commandname="Update"
runat="server"/>
<asp:linkbutton id="CancelButton"
text="Cancel"
commandname="Cancel"
runat="server"/>
</td>
</tr>
</table>
</edititemtemplate>
<pagersettings position="Bottom"
mode="Numeric"/>
</asp:formview>
<br/><br/>
<asp:label id="MessageLabel"
forecolor="Red"
runat="server"/>
<!-- This example uses Microsoft SQL Server and connects -->
<!-- to the Northwind sample database. Use an ASP.NET -->
<!-- expression to retrieve the connection string value -->
<!-- from the Web.config file. -->
<asp:sqldatasource id="EmployeeSource"
selectcommand="Select [EmployeeID], [LastName], [FirstName], [Title], [Address], [City], [Region], [PostalCode], [Country], [HireDate], [PhotoPath] From [Employees]"
updatecommand="Update [Employees] Set [LastName]=@LastName, [FirstName]=@FirstName, [Title]=@Title, [Address]=@Address, [City]=@City, [Region]=@Region, [PostalCode]=@PostalCode, [Country]=@Country Where [EmployeeID]=@EmployeeID"
connectionstring="<%$ ConnectionStrings:NorthWindConnectionString%>"
runat="server"/>
</form>
</body>
</html>
Keterangan
Antarmuka IBindableTemplate menyediakan cara untuk ASP.NET kontrol terikat data, seperti DetailsView, , GridViewdan FormView, untuk mengikat data yang disediakan oleh kontrol sumber data ASP.NET, seperti ObjectDataSource atau SqlDataSource, saat kontrol terikat data menyertakan konten yang di-template.
Catatan
Pengembang halaman tidak mengimplementasikan IBindableTemplate antarmuka. Pengembang yang membuat kontrol terikat data kustom mungkin memanipulasi objek dalam implementasi IBindableTemplatePerformDataBinding metode dan ExtractRowValues , tetapi tidak menerapkan objek mereka sendiri IBindableTemplate .
Kontrol terikat data seperti GridView biasanya mengetahui pohon kontrol anak mereka, dan karenanya dapat mengikat nilai kepada mereka, mengekstrak nilai dari mereka, dan meneruskan nilai-nilai ini antara kontrol terikat data dan kontrol sumber data setiap kali pengikatan data terjadi. Namun, ketika pengembang halaman menentukan konten templat untuk kontrol terikat data, kontrol anak dalam templat tidak terlihat oleh kontrol terikat data induk: induk dapat merender konten anak (karena kontrol merender sendiri secara efektif), tetapi tidak dapat mengekstrak nilai kontrol anak ini untuk diteruskan ke pembaruan kontrol sumber data terkait, sisipkan, atau hapus operasi. Dalam skenario pengikatan data, konten templat buram ke kontrol terikat data induk.
Bind
Sintaks memungkinkan kontrol terikat data untuk mengekstrak nilai dari data kontrol yang terikat di dalam IBindableTemplate instans.
Pengikatan data bisa satu arah atau dua arah. (Arah pengikatan ini ditentukan oleh BindingDirection enumerasi.) Pengikatan data satu arah adalah pengikatan data apa pun yang dilakukan dalam arah keluar, dari kontrol sumber data hingga kontrol terikat data; misalnya, skenario pembacaan data apa pun melibatkan pengikatan data satu arah. Untuk pengikatan data satu arah, Anda dapat menggunakan sintaks pengikatan data satu arah (<%# Eval("fieldname") %>
) di dalam konten templat, dan tidak perlu menggunakan sintaks pengikatan data ASP.NET dua arah. Pengikatan data dua arah menjelaskan pengikatan data ke arah masuk, dari kontrol terikat data ke kontrol sumber data. Skenario edit, sisipkan, dan hapus otomatis menggunakan ASP.NET terikat data dan kontrol sumber data adalah skenario pengikatan data dua arah. Skenario ini menggunakan ekspresi pengikatan data dua arah (<%# Bind("fieldname") %>
). Antarmuka IBindableTemplate dan infrastruktur ASP.NET mendukung pengikatan data dua arah otomatis, deklaratif antara kontrol sumber data ASP.NET dan konten templat. Untuk informasi selengkapnya tentang ASP.NET ekspresi dan sintaks pengikatan data, lihat Ikatan ke Database dan Gambaran Umum Ekspresi Pengikatan Data.
Konten templat untuk kontrol terikat data paling sering ditentukan secara deklaratif. Tabel berikut ini menjelaskan proses yang paling umum digunakan untuk mengikat data templat ke kontrol terikat data.
Kontrol terikat data | Proses |
---|---|
DetailsView | Kontrol terikat data terikat ke data menggunakan DataSourceID properti kontrol sumber data, dan konten templat ditentukan dalam ItemTemplateproperti , EditItemTemplate atau InsertItemTemplate . |
GridView | Kontrol terikat data terikat ke data menggunakan DataSourceID properti kontrol sumber data, dan konten templat ditentukan dalam ItemTemplate properti atau EditItemTemplate . Kontrol GridView tidak mendukung operasi penyisipan. |
FormView | Kontrol terikat data terikat ke data menggunakan DataSourceID properti , dan konten templat ditentukan dalam ItemTemplateproperti , , InsertItemTemplateatau EditItemTemplate , atau dalam TemplateField objek . |
DataList Kontrol dan Repeater tidak mendukung skenario pengikatan data dua arah otomatis.
ASP.NET secara implisit IBindableTemplate membuat objek saat konten templat yang mengikat kontrol sumber data ASP.NET dalam templat diurai. Secara khusus, pengurai ASP.NET membuat instans CompiledBindableTemplateBuilder kelas saat mengurai konten templat yang menggunakan sintaks pengikatan data ASP.NET dan berisi kontrol server web ASP.NET yang mendukung pengikatan data. Kontrol sever ASP.NET ini ditandai oleh BindableAttribute atribut .
Antarmuka IBindableTemplate mendefinisikan satu metode, ExtractValues. Metode ini didefinisikan untuk pengikatan data dua arah, sehingga kontrol terikat data dapat secara otomatis mengekstrak pasangan nama/nilai dari konten templat dan meneruskan pasangan ke kontrol sumber data pada durasi. Agar pengikatan data otomatis berhasil, nama bidang yang diekstrak dari konten templat dengan metode harus cocok dengan ExtractValues nama parameter dalam kontrol sumber data terkait. Pengembang kontrol memanggil ExtractValues metode secara eksplisit hanya dalam implementasi mereka atau ExtractRowValues beberapa metode serupa lainnya dari kontrol terikat data kustom.
Metode
ExtractValues(Control) |
Saat diimplementasikan oleh kelas, mengambil sekumpulan pasangan nama/nilai untuk nilai yang terikat menggunakan sintaks pengikatan data ASP.NET dua arah dalam konten yang di-template. |
InstantiateIn(Control) |
Saat diimplementasikan oleh kelas, menentukan Control objek tempat kontrol dan templat anak berada. Kontrol anak ini pada gilirannya ditentukan dalam templat sebaris. (Diperoleh dari ITemplate) |