Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations IamaSherpa on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

onclick and onscroll issue

Status
Not open for further replies.

tweakmy

Programmer
Jan 14, 2008
3
DE
Hi to all javascript coder,
Sorry dont have any idea how i should name the title.I hope this thread will get some attention from some expert here.

My intention is simple. There will be a minimize menu moving as you scroll down.this minimize menu can be expandable at any time.it can be expanded and it can be minimize as well.

All the function i describe above work but when i click to expand/minimize for the menu. the scroll is return to the very top of the page and thus the menu will be shown expand and minimize on the very top of the page as well. what i want is that when minimized/expanded menu is click, the menu should minimize/expand at the current scroll position and not reset to the top.

can anyone show me how do i modify the code below?

Code:
<html>
<head>
<style type="text/css">
span{
position:absolute;
top:10px;
right:20px;
z-index:200;
background-color:white;
}
</style>
</head>


<body onscroll ="repositionhelpmenu()">
<span>
<a href='#' onclick='showhidemenu()'>show help</a>
<table style='background-color:white;display:none;'>
.....table content with static element, tr and td only
(5 rows 2 columns maximum here)
</table>
</span>


<table class='data'>
...table content with static element, tr and td only
(1000 rows 10 columns maximum here)
</table>
</body>

<script language='javascript' type='text/javascript'>
function showhidemenu()
{
var spanvar = document.getElementsByTagName("span")[0]
if(spanvar.getElementsByTagName("a").innerHTML=="hide")
(
spanvar.getElementsByTagName("table")[0].style.display="none"
spanvar.getElementsByTagName("a")[0].innerHTML="show help"
)
else if(spanvar.getElementsByTagName("a").innerHTML=="show help")
(
spanvar.getElementsByTagName("table")[0].style.display="block"
spanvar.getElementsByTagName("a")[0].innerHTML="hide"
)
}

function repositionhelpmenu()
{
var spanvar = document.getElementsByTagName("span")[0]
spanvar.style.top=document.getElementsByTagName("body")[0].scrollTop + 20
}

</script>
</html>
 
I can't actually get the above code to work... but I think if you change the code to this:

<a href='#help#' onclick='showhidemenu()'>show help</a>

<table class='data'>
<a href='help'>

This should give you your desired effect.

Adam
 
thank you. i did work out. mind explaining a bit.

I ve changed from:<a href='#' onclick='showhidemenu()'>show help</a>

to:
<a href='#help#' onclick='showhidemenu()'>show help</a>


 
Ok so that worked?

Sorry I should of explained a little more.. Ok...

So the page doesn't have to go to a .html, .asp file, etc you can place a # in the href, that simply calls it self. But this forces the window to jump back up to the top.

<a href='#' onclick='showhidemenu()'>show help</a>

<a href='#help#' onclick='showhidemenu()'>show help</a>

By placing an Anchor <a href='help'> the page has now somewhere to jump to. So the #help# targets whereever the <a href='help'> is on the page.

Make sense... not too good at explaining things.

Thanks
Adam
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top