Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

Atteint de JavaScriptite Aiguë [Cyril Durand]

Expert ASP.net Ajax et WCF, Cyril Durand parle dans son blog de point techniques sur ASP.net, ASP.net Ajax, JavaScript, WCF et .net en général. Cyril est également consultant indépendant, n'hésitez pas à le contacter pour de l'assistance sur vos projets

Actualités

  • Blog de Cyril DURAND, passionné de JavaScript, Ajax, ASP.net et tout ce qui touche au developpement Web Client-Side.

    N'hésitez pas à me contacter pour vos projets .net : architecture, accompagnement, formation, ...

    View Cyril Durand's profile on LinkedIn
    hit counters


    Expertise Commerce server et BizTalk

UpdateProgress et display:block, comment mettre son updateprogress a cote de son texte ?

L'UpdateProgress est un contrôle Microsoft Ajax qui permet d'afficher du HTML pendant que l'action de l'UpdatePanel s'effectue :

<asp:UpdatePanel ID="up1" runat="server" UpdateMode="Conditional" RenderMode="Inline"> <ContentTemplate> <%=DateTime.Now.ToLongTimeString()%> <asp:Button ID="btn1" runat="server" Text="toto" OnClick="wait" /> </ContentTemplate> </asp:UpdatePanel> <asp:UpdateProgress ID="upg1" runat="server" AssociatedUpdatePanelID="up1"> <ProgressTemplate> action en cours </ProgressTemplate> </asp:UpdateProgress>

Lorsque l'on click sur le bouton notre UpdateProgress s'affiche bien, par contre il s'affichera en dessous du bouton. En effet, contrairement à l'UpdatePanel, ce contrôle n'a pas de propriété RenderMode qui lui permetrais d'avoir un rendu "en-ligne" plutot que "block" (div / span). De plus le contrôle hérite directement de Control non pas de WebControl on ne peut donc pas même pas modifier les styles, ni hériter pour simplement surcharger la propriété TagKey. On pourrait utiliser un adapter de rendu mais cela ne suffirais pas, et cela devient bien compliqué pour un simple oublie de l'équipe Atlas; oublie qui d'ailleurs n'est pas le seul sur ce contrôle ...

Comment faire alors ?

Première solution avec CSS :

On met la propriété DynamicLayout de l'updateprogress à false puis on force le display en-ligne en CSS. Le problème de cette solution est qu'en définissant la propriété DynamicLayout à false, le JavaScript va afficher ou masquer l'UpdateProgress seulement en jouant avec la propriété CSS visibility; l'UpdateProgress sera donc présent dans le flux mais invisible pour l'utilisateur. Autrement dit, il prendra toujours sa place.

<style type="text/css"> div.DummyUpdateProgress, div.DummyUpdateProgress div { display:inline!important; } </style>
<div class="DummyUpdateProgress"> <asp:UpdateProgress ID="upg1" runat="server" AssociatedUpdatePanelID="up1" DynamicLayout="false"> <ProgressTemplate> action en cours </ProgressTemplate> </asp:UpdateProgress> </div>

Deuxième solution avec JavaScript :

La méthode consiste à réécrire la méthode Sys.UI._UpdateProgress.prototype._startRequest, c'est cette méthode qui définit le display de l'UpdateProgress :

Sys.Application.add_init(function(){ Type.registerNamespace('CS.Fix') CS.Fix.UpdateProgressInlineRenderModeIDs = [] Sys.UI._UpdateProgress.prototype.__CS_startRequest = Sys.UI._UpdateProgress.prototype._startRequest; Sys.UI._UpdateProgress.prototype._startRequest = function(sender, arg){ if (this._dynamicLayout && this._pageRequestManager.get_isInAsyncPostBack() && Array.contains(CS.Fix.UpdateProgressInlineRenderModeIDs, this.get_id())) { this.get_element().style.display = 'inline'; } } });

Il ne nous reste maintenant plus qu'a ajouté le clientID de l'updateProgress à modifié dans la collection CS.Fix.UpdateProgressInlineRenderModeIDs, pour cela on utiliser la méthode ScriptManager.RegisterStartupScript :

ScriptManager.RegisterStartupScript(this, typeof(_Default), "FixUpdateProgress" + upg1.ClientID, String.Format(@"Sys.Application.add_init(function(){{ CS.Fix.UpdateProgressInlineRenderModeIDs.push('{0}'); }});", upg1.ClientID), true);

Libre à vous ensuite de faire un contrôle qui hérite de UpdateProgress possédant une propriété RenderMode qui enregistre automatiquement le clientID dans le tableau d'UpdateProgress à modifier.

Posted: vendredi 25 mai 2007 03:16 par cyril
Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :

Commentaires

Pas de commentaires

Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- Etendre le Team Web Access de TFS 2012 – Step 0 par Philippe Didiergeorges Aka Philess le il y a 55 minutes

- Simuler facilement l’envoi de mail par Blog de Jérémy Jeanson le 05-22-2013, 12:52

- ProcDump 6.0 : support du filtrage sur messages d'exceptions .NET, des filtres multiples et du ciblage par nom de service par CoqBlog le 05-20-2013, 14:50

- Votez pour le TOP 10 des influenceurs SharePoint francophones ! par Le blog de Patrick [MVP SharePoint] le 05-20-2013, 12:59

- [Conf’SharePoint] Dernier rappel ! :-) par Le blog de Patrick [MVP SharePoint] le 05-20-2013, 09:09

- [ #SharePoint 2013 ] les modèles de sites standards… par Le blog de Patrick [MVP SharePoint] le 05-20-2013, 09:03

- 10 erreurs de compréhension concernant SharePoint… par Le blog de Patrick [MVP SharePoint] le 05-20-2013, 08:27

- Conf’SharePoint : 10 bonnes raisons pour ne pas la rater par Le petit blog de Pierre / Pierre's little blog le 05-14-2013, 02:24

- [Event] Soirée de lancement Agile .NET France à Lyon par Blog Agile/ALM de Vincent THAVONEKHAM le 05-13-2013, 01:29

- .NET / Debug : inspection de la mémoire d'applications .NET (dump ou processus live) : première livraison d'une librairie .NET par Microsoft par CoqBlog le 05-11-2013, 22:21