Partager via


Syntaxe de balise object côté serveur

Mise à jour : novembre 2007

Déclare et crée des objets COM et .NET Framework dans un page Web Forms.

<object id="id" 
        runat="server" 
        latebinding="true|false" 
        class="Class Name">
<object id="id" 
        runat="server" 
        latebinding="true|false" 
        progid="COM ProgID"/>
<object id="id" 
        runat="server" 
        latebinding="true|false" 
        classid="COM ClassID"/>

Attributs

  • class
    Spécifie la classe .NET Framework à créer.

  • classID
    Spécifie le composant COM à créer à l'aide de l'identificateur de classe du composant.

  • id
    Nom unique à utiliser lors du référencement de l'objet dans le code suivant.

  • lateBinding
    Précise si des interfaces API à liaison tardive doivent être utilisées avec des composants COM traités par l'importateur de bibliothèques de types (Tlbimp.exe). La valeur true indique que des interfaces API à liaison tardive doivent être utilisées ; false indique que des interfaces API à liaison anticipée doivent être utilisées. La valeur par défaut est false.

  • progID
    Spécifie le composant COM à créer en spécifiant l'identificateur programmatique du composant.

  • runat
    Doit avoir la valeur server pour que l'objet s'exécute dans ASP.NET. Si d'autres valeurs sont utilisées, le compilateur de pages suppose que la balise <object> doit être envoyée au client pour gestion.

Notes

Lorsque l'analyseur de pages ASP.NET rencontre une balise <object> côté serveur dans un fichier .aspx, il génère une propriété en lecture seule sur la page, en utilisant l'attribut id de la balise comme nom de propriété. La propriété en lecture seule est alors configurée pour créer une instance de l'objet à la première utilisation. L'instance résultante n'est pas ajoutée en tant qu'objet dans l'arborescence de contrôles serveur hiérarchique de la page ; au lieu de cela, elle est traitée comme une déclaration de variable d'interface non utilisateur.

Les attributs classid, progid et class s'excluent mutuellement. Vous ne pouvez pas inclure plusieurs de ces attributs dans une même balise <object> côté serveur. En revanche, vous pouvez inclure plusieurs balises <object> côté serveur sur une page Web Forms et utiliser ces attributs dans différentes balises.

Remarque :

Pour des raisons de sécurité, les contrôles managés utilisant la balise <object> et le protocole d'accès aux fichiers dans une page HTML ne sont pas pris en charge. Par conséquent, vous ne pouvez pas référencer directement des fichiers à partir de la balise.

Exemple

L'exemple suivant utilise une syntaxe d'objets côté serveur pour créer une instance de la classe .NET Framework ArrayList dans une page Web Forms.

<%@Page language="C#" %>
<html>
   <object id="items" class="System.Collections.ArrayList" runat="server" />
   <script language="C#" runat=server>
      void Page_Load(Object sender, EventArgs e) {
         items.Add("One");
         items.Add("Two");
         items.Add("Three");

         MyList.DataSource = items;
         MyList.DataBind();
      }
   </script>

   <body>
      <form id="form1" runat="server">
      <asp:datalist id="MyList" runat=server>
         <ItemTemplate>
            Here is a value: <%# Container.DataItem %>
         </ItemTemplate>
      </asp:datalist>
      </form1>
   </body>
</html>
<%@Page language="VB" %>
<html>
   <object id="items" class="System.Collections.ArrayList" runat="server" />
   <script language="VB" runat=server>
      Sub Page_Load(Sender As Object, E As EventArgs)
         items.Add("One")
         items.Add("Two")
         items.Add("Three")

         MyList.DataSource = items
         MyList.DataBind()
      End Sub
   </script>

   <body>
      <form id="form1" runat="server">
      <asp:datalist id="MyList" runat=server>
         <ItemTemplate>
            Here is a value: <%# Container.DataItem %>
         </ItemTemplate>
      </asp:datalist>
      </form1>
   </body>
</html>

Voir aussi

Concepts

Vue d'ensemble de la syntaxe des pages Web ASP.NET

Introduction aux pages Web ASP.NET