簡體   English   中英

選擇時在GridPanel上划分

[英]Div over GridPanel at select

我的JavaScript不太好,現在真的很困。 我在表單上有一個updatepanel。 在此更新面板中,我有一個網格視圖。 當我單擊選擇按鈕時,我希望將Panel1顯示在桌子上,並將其左上角放置在我單擊的位置。

我已經用JavaScript編寫了一個將鼠標坐標保存到2個隱藏字段中的函數:

function  getMouseXY(event)
{
    var hiddenFieldX=$get('<%=mouseX.ClientID%>');
    var hiddenFieldY=$get('<%=mouseY.ClientID%>');

    if (navigator.appName=="Microsoft Internet Explorer")
    {
        hiddenFieldX.value = event.clientX + document.body.scrollLeft
        hiddenFieldY.value = event.clientY + document.body.scrollTop
    }
    else
    {
        hiddenFieldX.value=event.pageY
        hiddenFieldY.value=event.pageX
    }
}

之后,我必須在服務器端完成Panel1中的TextBox1。 如何將Panel1放置在所需位置? 我有設置面板坐標的功能:

function showDetails()
{
    var hiddenFieldX=$get('<%=mouseX.ClientID%>');
    var hiddenFieldY=$get('<%=mouseY.ClientID%>');

    var elem=$get("details") ;
    elem.style.left = hiddenFieldX.value+"px"
    elem.style.top = hiddenFieldY.value+"px"
}

但是你不知道我什么時候打電話。

    <asp:UpdatePanel ID="UpdatePanel1" runat="server">
       <ContentTemplate>
         <asp:HiddenField ID="showDetails" Value="false" runat="server" />
         <asp:HiddenField ID="mouseX" Value="0" runat="server" />
         <asp:HiddenField ID="mouseY" Value="0" runat="server" />


         <asp:Panel ID="Panel1" runat="server" style="border-color:Blue; border-style:double; border-width:thick; width : 200px; height:200px; position:absolute ; top:100px ; left: 100px; z-index:0" Visible="false">
             <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
         </asp:Panel>
         <asp:SqlDataSource ID="EnvoxDataSource" runat="server" </asp:SqlDataSource>
         <asp:GridView ID="gvRecherche" runat="server" AllowPaging="True" PageSize="30" Caption="Résultats" AllowSorting="True" CssClass="tableSeparator"
AutoGenerateColumns="False" DataSourceID="EnvoxDataSource"  
OnSelectedIndexChanged="gvRecherche_SelectedIndexChanged"  
onclick="getMouseXY(event)" >
             <PagerStyle BorderStyle="None"/>
             <HeaderStyle CssClass="tableSeparator" HorizontalAlign="Left"  />
             <AlternatingRowStyle CssClass="colorBlanc" />
             <RowStyle CssClass="colorGris" />
             <SelectedRowStyle BackColor="#FFCC66" Font-Bold="true" ForeColor="#659bed" />
             <Columns>
                 <asp:CommandField InsertVisible="False" SelectImageUrl="~/App_Themes/Standard/images/selectbtn20X20.PNG" SelectText="Select" ShowCancelButton="False" ShowSelectButton="True" ButtonType="Image"   />
                <asp:BoundField DataField="ContactID" HeaderText="ContactID" ReadOnly="True" SortExpression="ContactID"/>
                <asp:BoundField DataField="TimeInIVR" HeaderText="TimeInIVR" ReadOnly="True" SortExpression="TimeInIVR" />
                <asp:BoundField DataField="TQ" HeaderText="TQ" ReadOnly="True" SortExpression="TQ"/>
           </Columns>
           <EmptyDataTemplate>
               <div class="message">Aucun résultat pour ces critères</div>
           </EmptyDataTemplate>
           <PagerSettings Mode="NumericFirstLast" Position="TopAndBottom"         LastPageText="&gt;&gt;" FirstPageText="&lt;&lt;" />
     </asp:GridView> 
     <br />
     <asp:Button ID="btnImprime" runat="server" Text="Version Imprimable" Visible="False" CssClass="bouton" PostBackUrl="<%# GetEnvoxPrintUrl() %>"  target="_blanc" />            
     &nbsp;&nbsp;&nbsp;
     <script language="javascript" type="text/javascript">showDetails()</script> 
 </ContentTemplate>
</asp:UpdatePanel>

謝謝

嘗試這個。 我認為點擊gv按鈕會導致部分回發,並且可以通過以下JavaScript進行攔截:

<script type="text/javascript" language="javascript">
    Sys.WebForms.PageRequestManager.getInstance().add_beginRequest(BeginRequestHandler);
    function BeginRequestHandler(sender, args)
    {
        showDetails(); // Your javascript
    }
</script>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM