Traduction

Cet article est la traduction la plus fidèle possible de l'article original de Christian Wenz: Adjusting the Z-Index of a DropShadow

Présentation

Le contrôle DropShadow de l'AJAX Control Toolkit étend les fonctionnalités d'un Panel avec une ombre. Toutefois, cette ombre entre parfois en conflit avec d'autres contrôles, par exemple, le contrôle de menu d'ASP.NET. Quand un menu apparaît, il s'affiche derrière l'ombre.

Etapes

Le code commence par le Panel lui-même, contenant suffisamment de texte pour que l'effet soit visible:

 
Sélectionnez

<asp:Panel ID="panelShadow" runat="server" CssClass="panel" Width="300px">
	ASP.NET AJAX is a free framework for quickly creating a new generation of more
	efficient, more interactive and highly-personalized Web experiences that work
	across all the most popular browsers.<br />
	ASP.NET AJAX is a free framework for quickly creating a new generation of more
	efficient, more interactive and highly-personalized Web experiences that work
	across all the most popular browsers.<br />
	ASP.NET AJAX is a free framework for quickly creating a new generation of more
	efficient, more interactive and highly-personalized Web experiences that work
	across all the most popular browsers.<br />
</asp:Panel>

Un autre Panel est placé directement devant le panel panelShadow. Il contient un menu d'orientation horizontale de sorte que les entrées du menu apparaîssent sur (ou plutôt sous) le Panel dropShadow) :

 
Sélectionnez

<asp:Panel ID="panelMenu" runat="server" CssClass="ForegroundStyle">
	<asp:Menu ID="menu1" runat="server" ForeColor="Red" Orientation="Horizontal">
		<Items>
			<asp:MenuItem Text="One">
				<asp:MenuItem Text="1.1" />
				<asp:MenuItem Text="1.2" />
			</asp:MenuItem>
			<asp:MenuItem Text="Two" />
			<asp:MenuItem Text="Three" />
		</Items>
	</asp:Menu>
	<br />
</asp:Panel>

Ensuite, le contrôle DropShadowExtender est ajouté afin étendre le panel panelShadow avec un effet d'ombre :

 
Sélectionnez

<ajaxToolkit:DropShadowExtender ID="dse1" runat="server" TargetControlID="panelShadow" 
	Opacity="0.5" Rounded="true" />

Enfin, le contrôle ScriptManager d'ASP.NET AJAX permet au Control Toolkit de fonctionner :

 
Sélectionnez

<asp:ScriptManager ID="asm" runat="server" />

Lorsque vous exécutez ce script, les éléments du menu apparaîssent sous le Panel. Cependant, le menu utilise la classe CSS du panel où il vous suffit de définir deux choses pour que les éléments apparaîssent par dessus l'autre Panel :

  • Un positionnement relatif
  • Le z-index positif
 
Sélectionnez

<style type="text/css">
	.ForegroundStyle {z-index: 123; position: relative;}
	.panel {background-color: navy;}
</style>

Ainsi, le contrôle DropShadowExtender n'est plus en conflit avec le contrôle Menu.

Image non disponible
Avant : l'élément du menu n'est pas visible
Image non disponible
Après : l'élément du menu apparaît