Udostępnij za pośrednictwem


DynamicControl.UIHint Właściwość

Definicja

Pobiera lub ustawia nazwę szablonu pola używanego do renderowania pola danych.

public:
 virtual property System::String ^ UIHint { System::String ^ get(); void set(System::String ^ value); };
public virtual string UIHint { get; set; }
member this.UIHint : string with get, set
Public Overridable Property UIHint As String

Wartość właściwości

String

Nazwa szablonu pola używanego do renderowania pola danych. Wartość domyślna to pusty ciąg (""), który wskazuje, że szablon pola zostanie renderowany na podstawie typu pola danych lub informacji o metadanych zastosowanych do modelu danych.

Przykłady

Zobacz przykład kodu w czasie wykonywania tej funkcji: Uruchom.

W poniższym przykładzie pokazano, jak określić pole danych, aby użyć innego szablonu pola do renderowania jego zawartości. W drugim przykładzie pokazano szablon pola niestandardowego UIHint określony przez właściwość.

<%@ 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">
  protected void Page_Init(object sender, EventArgs e)
  {
    DynamicDataManager1.RegisterControl(Repeater1);
  }
</script>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  <title>DynamicControl.UIHint Sample</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
      <asp:DynamicDataManager ID="DynamicDataManager1" runat="server"
        AutoLoadForeignKeys="true" />
        
      <asp:Repeater ID="Repeater1" runat="server" DataSourceID="LinqDataSource1">
        <HeaderTemplate>
          <table border="1">
            <tr>
               <th>First Name</th>
               <th>Last Name</th>
               <th>Email</th>
            </tr>        
        </HeaderTemplate>
        <ItemTemplate>
          <tr>
            <td><asp:DynamicControl runat="server" DataField="FirstName" /></td>
            <td><asp:DynamicControl runat="server" DataField="LastName" /></td>
            <td><asp:DynamicControl runat="server" DataField="EmailAddress" UIHint="Email" /> </td>
          </tr>
        </ItemTemplate>
        <FooterTemplate>
          </table>
        </FooterTemplate>
      </asp:Repeater>

      <asp:LinqDataSource ID="LinqDataSource1" runat="server" 
        TableName="Customers"
        ContextTypeName="AdventureWorksLTDataContext">
      </asp:LinqDataSource>
    </div>
    </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">

  Protected Sub Page_Init(ByVal sender As Object, ByVal e As System.EventArgs)    
    DynamicDataManager1.RegisterControl(Repeater1)
  End Sub

</script>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  <title>DynamicControl.UIHint Sample</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
      <asp:DynamicDataManager ID="DynamicDataManager1" runat="server"
        AutoLoadForeignKeys="true" />
        
      <asp:Repeater ID="Repeater1" runat="server" DataSourceID="LinqDataSource1">
        <HeaderTemplate>
          <table border="1">
            <tr>
               <th>First Name</th>
               <th>Last Name</th>
               <th>Email</th>
            </tr>        
        </HeaderTemplate>
        <ItemTemplate>
          <tr>
            <td><asp:DynamicControl runat="server" DataField="FirstName" /></td>
            <td><asp:DynamicControl runat="server" DataField="LastName" /></td>
            <td><asp:DynamicControl runat="server" DataField="EmailAddress" UIHint="Email" /> </td>
          </tr>
        </ItemTemplate>
        <FooterTemplate>
          </table>
        </FooterTemplate>
      </asp:Repeater>

      <asp:LinqDataSource ID="LinqDataSource1" runat="server" 
        TableName="Customers"
        ContextTypeName="AdventureWorksLTDataContext">
      </asp:LinqDataSource>
    </div>
    </form>
</body>
</html>
<%@ Control Language="C#" ClassName="Email" Inherits="System.Web.DynamicData.FieldTemplateUserControl"%>

<script runat="server">
  protected string GetNavigateUrl()
  {
    if (!String.IsNullOrEmpty(FieldValueString))
    {
      return "mailto:" + FieldValueString;
    }

    return string.Empty;
  }
</script>

<asp:HyperLink ID="EmailAddressLink" runat="server"
    Text="<%# FieldValueString %>"
    NavigateUrl="<%# GetNavigateUrl() %>"  />
<%@ Control Language="VB" ClassName="Email" Inherits="System.Web.DynamicData.FieldTemplateUserControl"%>

<script runat="server">
    
    Protected Function GetNavigateUrl() As String

        If (Not String.IsNullOrEmpty(FieldValueString)) Then
            Return "mailto:" & FieldValueString
        End If
    
        Return String.Empty

    End Function
    
</script>

<asp:HyperLink ID="EmailAddressLink" runat="server"
    Text="<%# FieldValueString %>"
    NavigateUrl="<%# GetNavigateUrl() %>"  />

Uwagi

UIHint Użyj właściwości , aby określić szablon pola, który ma być używany do wyświetlania interfejsu użytkownika dla pola danych. Szablony pól domyślnie to kontrolki użytkownika, a ich nazwy zawierają sufiks do identyfikowania szablonów pól używanych do edytowania operacji i wstawiania operacji. Sufiksy są odpowiednio _edit i _insert. Po ustawieniu wartości na właściwość należy ustawić UIHint nazwę bez sufiksów. Dane dynamiczne zidentyfikują prawidłowy tryb, oceniając Mode wartość właściwości i renderując prawidłowy szablon pola.

UIHint Jeśli właściwość nie jest ustawiona, domyślnie dane dynamiczne będą renderować szablon pola na podstawie typu pola. Aby uzyskać więcej informacji, zobacz ASP.NET tworzenie szkieletu danych dynamicznych.

Szablon pola określony przy użyciu UIHint właściwości jest specyficzny dla tego wystąpienia kontrolki DynamicControl . Możesz również zmienić szablon pola używany przez pole danych w całej aplikacji, stosując element UIHintAttribute do modelu danych. UIHint Ustawienie właściwości zastępuje metadane zastosowane do modelu danych. Aby uzyskać więcej informacji na temat atrybutów metadanych, zobacz ASP.NET dane dynamiczne.

Dotyczy

Zobacz też