Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

GridView - Remember position of horizontal scrollbar on postback

Posted on 2008-11-01
5
Medium Priority
?
1,976 Views
Last Modified: 2013-11-19
Hi
I have a gridview that is dynamically filled in - so don't know how many columns in design view.  
The columns need to be variable width - this is done in the Row_Created

   Dim td As TableCell
   For x = 1 To e.Row.Cells.Count - 1
     td = e.Row.Cells(x)
     td.Width = 70
   Next


I came to this after help on EE.


The horizontal scroll is displayed and user can navigate to right on gridview - gridview can't all be fitted on screen, maybe up to XXX columns.
The gridview column titles have link.  On clicking the link, there is a postback and values at top of screen are updated according to the column selected detailing all outputs in more user friendly way than a table.

The problem...
On postback, the horizontal position of scrollbar is forgotten. So the user could have scrolled well to the right off gridview to column 50 say, then on postback the horizontal scrollbar returns to left (column 1), and if the wanted detailed on column 51 they have to scroll all the way to right again.

So I want to maintain horizontal position of scrollbar if possible so user doesn't have to scroll all way to right again.
Had problems with AJAX on this page so don't want that route.

Thanks in advance
<asp:Panel ID="TablePanel" runat="server" Width="800px" Style="overflow: scroll;
     border: gray thin solid; border-width: 1px;" BorderColor="#FF6600">
     <div id="gridViewDiv" style="width: 5000px; background-color: Silver;">
         <asp:GridView ID="GridView1" runat="server" BackColor="white" GridLines="both" BorderStyle="Solid">
         </asp:GridView>
     </div>
</asp:Panel>

Open in new window

0
Comment
Question by:rwallacej
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 2
5 Comments
 
LVL 16

Accepted Solution

by:
Gyanendra Singh earned 2000 total points
ID: 22856264
refer this link .. it will resolve your problem
http://forums.devx.com/showthread.php?t=154117
0
 

Author Comment

by:rwallacej
ID: 22856306
hi,
thanks for feedback.

I've taken the markup as Javascript from bottom of article (which seemed to be the solution), see below, but still don't retain positon.
I have put alert in the javascript to check it is called and it is.

can you advise further, please?
                <blockquote>
                    <div id="grdWithScroll" style="overflow:auto; width: 400px; background-color: Silver;" onscroll="SetDivPosition()">
                        <asp:GridView ID="GridView1" runat="server" BackColor="white" GridLines="both" BorderStyle="Solid">
                        </asp:GridView>
                    </div>
                </blockquote>
 
 
 
   <script type="text/javascript">
      window.onload = function(){
        var strCook = document.cookie;
        if(strCook.indexOf("!~")!=0){
          var intS = strCook.indexOf("!~");
          var intE = strCook.indexOf("~!");
          var strPos = strCook.substring(intS+2,intE);
          document.getElementById("grdWithScroll").scrollTop = strPos;
        }
      }
      
      function SetDivPosition(){
        var intY = document.getElementById("grdWithScroll").scrollTop;
        document.title = intY;
        document.cookie = "yPos=!~" + intY + "~!";
      }
    </script>

Open in new window

0
 

Author Comment

by:rwallacej
ID: 22856340
I should have put the code when it was changed to the position LEFT (I'm not bothered about vertical position). Here it is, but doesn't work
       window.onload = function(){
        var strCook = document.cookie;
        if(strCook.indexOf("!~")!=0){
            var intS = strCook.indexOf("!~");
            var intE = strCook.indexOf("~!");
            var strPos = strCook.substring(intS+2,intE);
            document.getElementById("grdWithScroll").scrollLeft = strPos;
        }
      }
      
      function SetDivPosition(){
        var intX = document.getElementById("grdWithScroll").scrollLeft;
        document.title = intX;
        document.cookie = "xPos=!~" + intX + "~!";
      }

Open in new window

0
 

Author Closing Comment

by:rwallacej
ID: 31512295
go it thanks.....needed to be the reference on my TablePanel not the DIV contained therein.
thank-you very much,
rwallacej
0
 
LVL 16

Expert Comment

by:Gyanendra Singh
ID: 22856978
your welcome
0

Featured Post

The top UI technologies you need to be aware of

An important part of the job as a front-end developer is to stay up to date and in contact with new tools, trends and workflows. That’s why you cannot miss this upcoming webinar to explore the latest trends in UI technologies!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

JavaScript has plenty of pieces of code people often just copy/paste from somewhere but never quite fully understand. Self-Executing functions are just one good example that I'll try to demystify here.
Nothing in an HTTP request can be trusted, including HTTP headers and form data.  A form token is a tool that can be used to guard against request forgeries (CSRF).  This article shows an improved approach to form tokens, making it more difficult to…
The viewer will learn how to count occurrences of each item in an array.
The viewer will receive an overview of the basics of CSS showing inline styles. In the head tags set up your style tags: (CODE) Reference the nav tag and set your properties.: (CODE) Set the reference for the UL element and styles for it to ensu…

688 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question