网页的顶端总在页面上,就是拉动滚动条,顶端不变,但不用框架页,有办法吗?

时间:2023-01-07 13:15:27
网页的顶端总在页面上,就是拉动滚动条,顶端不变,但不用框架页,有办法吗? 
因为框架不支持下拉菜单:(

9 个解决方案

#1


不用框架好象不行吧,至少我没那能耐,关注!

#2


用层呀!div or layer.上下分两层,单独控制就可以了。这是对不支持框架的浏览器的替代方法,不过也要注意不同浏览器对层的支持不同呀!

#3


难!!

#4


层应该能实现,不知道下拉菜单如何?

#5


用层可以实现,网上有很多例子,你仔细找找看。

#6


用层,位置固定在顶端

#7


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
</HEAD>
<SCRIPT language=JavaScript>
self.onError=null;
currentX = currentY = 0;  
whichIt = null;   
         lastScrollX = 0; lastScrollY = 0;
NS = (document.layers) ? 1 : 0;
IE = (document.all) ? 1: 0;
<!-- STALKER CODE -->
function heartBeat() {
if(IE) { diffY = document.body.scrollTop; diffX = document.body.scrollLeft; }
    if(NS) { diffY = self.pageYOffset; diffX = self.pageXOffset; }
if(diffY != lastScrollY) {                 percent = .1 * (diffY - lastScrollY);
                if(percent > 0) percent = Math.ceil(percent);
                else percent = Math.floor(percent); if(IE) document.all.floater.style.pixelTop += percent;
if(NS) document.floater.top += percent;                  lastScrollY = lastScrollY + percent;
    }
if(diffX != lastScrollX) {
percent = .1 * (diffX - lastScrollX);
if(percent > 0) percent = Math.ceil(percent);
else percent = Math.floor(percent);
if(IE) document.all.floater.style.pixelLeft += percent;
if(NS) document.floater.left += percent;
lastScrollX = lastScrollX + percent;
}
} <!-- /STALKER CODE -->
<!-- DRAG DROP CODE -->
function checkFocus(x,y) { 
        stalkerx = document.floater.pageX;
        stalkery = document.floater.pageY;
        stalkerwidth = document.floater.clip.width;
        stalkerheight = document.floater.clip.height;
        if( (x > stalkerx && x < (stalkerx+stalkerwidth)) && (y > stalkery && y < (stalkery+stalkerheight))) return true;
        else return false;
} function grabIt(e) {
if(IE) {
whichIt = event.srcElement;
while (whichIt.id.indexOf("floater") == -1) {
whichIt = whichIt.parentElement;
if (whichIt == null) { return true; }
    }
whichIt.style.pixelLeft = whichIt.offsetLeft;
    whichIt.style.pixelTop = whichIt.offsetTop;
currentX = (event.clientX + document.body.scrollLeft);
    currentY = (event.clientY + document.body.scrollTop); 
} else { 
        window.captureEvents(Event.MOUSEMOVE);
        if(checkFocus (e.pageX,e.pageY)) { 
                whichIt = document.floater;
                StalkerTouchedX = e.pageX-document.floater.pageX;
                StalkerTouchedY = e.pageY-document.floater.pageY;
        }  }
    return true;
}
function moveIt(e) {
if (whichIt == null) { return false; }
if(IE) {
    newX = (event.clientX + document.body.scrollLeft);
    newY = (event.clientY + document.body.scrollTop);
    distanceX = (newX - currentX);    distanceY = (newY - currentY);     currentX = newX;    currentY = newY;
    whichIt.style.pixelLeft += distanceX;     whichIt.style.pixelTop += distanceY;
if(whichIt.style.pixelTop < document.body.scrollTop) whichIt.style.pixelTop = document.body.scrollTop; if(whichIt.style.pixelLeft < document.body.scrollLeft) whichIt.style.pixelLeft = document.body.scrollLeft;
if(whichIt.style.pixelLeft > document.body.offsetWidth - document.body.scrollLeft - whichIt.style.pixelWidth - 20) whichIt.style.pixelLeft = document.body.offsetWidth - whichIt.style.pixelWidth - 20;
if(whichIt.style.pixelTop > document.body.offsetHeight + document.body.scrollTop - whichIt.style.pixelHeight - 5) whichIt.style.pixelTop = document.body.offsetHeight + document.body.scrollTop - whichIt.style.pixelHeight - 5;
event.returnValue = false;
} else {
whichIt.moveTo(e.pageX-StalkerTouchedX,e.pageY-StalkerTouchedY);
        if(whichIt.left < 0+self.pageXOffset) whichIt.left = 0+self.pageXOffset;
        if(whichIt.top < 0+self.pageYOffset) whichIt.top = 0+self.pageYOffset;
        if( (whichIt.left + whichIt.clip.width) >= (window.innerWidth+self.pageXOffset-17)) whichIt.left = ((window.innerWidth+self.pageXOffset)-whichIt.clip.width)-17;
        if( (whichIt.top + whichIt.clip.height) >= (window.innerHeight+self.pageYOffset-17)) whichIt.top = ((window.innerHeight+self.pageYOffset)-whichIt.clip.height)-17;
        return false;
}
    return false;
}
function dropIt() {
whichIt = null;
    if(NS) window.releaseEvents (Event.MOUSEMOVE);


    return true;
}
<!-- DRAG DROP CODE -->
if(NS) {
window.captureEvents(Event.MOUSEUP|Event.MOUSEDOWN);
window.onmousedown = grabIt;
  window.onmousemove = moveIt;
window.onmouseup = dropIt;
}
if(IE) {
document.onmousedown = grabIt;
  document.onmousemove = moveIt;
document.onmouseup = dropIt;
}
if(NS || IE) action = window.setInterval("heartBeat()",1);
</SCRIPT>

<BODY>
<DIV id=floater style="Z-INDEX: 1; LEFT: 0px; WIDTH: 754px; POSITION: absolute; TOP: 0px; HEIGHT: 27px; background: #CCCCCC; layer-background-color: #CCCCCC; border: 1px none #000000;"> 
  <table width="100%" border="0">
<tr> 
  <td><div align="center"><font color="#FF0000" face="impact">总在顶端</font></div></td>
</tr>
<tr>
  <td><div align="center"><a href="#top"><font color="#FF0000" face="impact">↑TOP↑</font></a></div></td>
</tr> 
</table>
</DIV>
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
</BODY>
</HTML>


你看这样行不..效果有点差

#8


层能不动么?层上能做下拉菜单么?

#9


把你需要滚动的内容放到<div></div>中,
div标签加上 style="overflow:auto; position:absolute; width:宽px; height:高px;"的属性。

#1


不用框架好象不行吧,至少我没那能耐,关注!

#2


用层呀!div or layer.上下分两层,单独控制就可以了。这是对不支持框架的浏览器的替代方法,不过也要注意不同浏览器对层的支持不同呀!

#3


难!!

#4


层应该能实现,不知道下拉菜单如何?

#5


用层可以实现,网上有很多例子,你仔细找找看。

#6


用层,位置固定在顶端

#7


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
</HEAD>
<SCRIPT language=JavaScript>
self.onError=null;
currentX = currentY = 0;  
whichIt = null;   
         lastScrollX = 0; lastScrollY = 0;
NS = (document.layers) ? 1 : 0;
IE = (document.all) ? 1: 0;
<!-- STALKER CODE -->
function heartBeat() {
if(IE) { diffY = document.body.scrollTop; diffX = document.body.scrollLeft; }
    if(NS) { diffY = self.pageYOffset; diffX = self.pageXOffset; }
if(diffY != lastScrollY) {                 percent = .1 * (diffY - lastScrollY);
                if(percent > 0) percent = Math.ceil(percent);
                else percent = Math.floor(percent); if(IE) document.all.floater.style.pixelTop += percent;
if(NS) document.floater.top += percent;                  lastScrollY = lastScrollY + percent;
    }
if(diffX != lastScrollX) {
percent = .1 * (diffX - lastScrollX);
if(percent > 0) percent = Math.ceil(percent);
else percent = Math.floor(percent);
if(IE) document.all.floater.style.pixelLeft += percent;
if(NS) document.floater.left += percent;
lastScrollX = lastScrollX + percent;
}
} <!-- /STALKER CODE -->
<!-- DRAG DROP CODE -->
function checkFocus(x,y) { 
        stalkerx = document.floater.pageX;
        stalkery = document.floater.pageY;
        stalkerwidth = document.floater.clip.width;
        stalkerheight = document.floater.clip.height;
        if( (x > stalkerx && x < (stalkerx+stalkerwidth)) && (y > stalkery && y < (stalkery+stalkerheight))) return true;
        else return false;
} function grabIt(e) {
if(IE) {
whichIt = event.srcElement;
while (whichIt.id.indexOf("floater") == -1) {
whichIt = whichIt.parentElement;
if (whichIt == null) { return true; }
    }
whichIt.style.pixelLeft = whichIt.offsetLeft;
    whichIt.style.pixelTop = whichIt.offsetTop;
currentX = (event.clientX + document.body.scrollLeft);
    currentY = (event.clientY + document.body.scrollTop); 
} else { 
        window.captureEvents(Event.MOUSEMOVE);
        if(checkFocus (e.pageX,e.pageY)) { 
                whichIt = document.floater;
                StalkerTouchedX = e.pageX-document.floater.pageX;
                StalkerTouchedY = e.pageY-document.floater.pageY;
        }  }
    return true;
}
function moveIt(e) {
if (whichIt == null) { return false; }
if(IE) {
    newX = (event.clientX + document.body.scrollLeft);
    newY = (event.clientY + document.body.scrollTop);
    distanceX = (newX - currentX);    distanceY = (newY - currentY);     currentX = newX;    currentY = newY;
    whichIt.style.pixelLeft += distanceX;     whichIt.style.pixelTop += distanceY;
if(whichIt.style.pixelTop < document.body.scrollTop) whichIt.style.pixelTop = document.body.scrollTop; if(whichIt.style.pixelLeft < document.body.scrollLeft) whichIt.style.pixelLeft = document.body.scrollLeft;
if(whichIt.style.pixelLeft > document.body.offsetWidth - document.body.scrollLeft - whichIt.style.pixelWidth - 20) whichIt.style.pixelLeft = document.body.offsetWidth - whichIt.style.pixelWidth - 20;
if(whichIt.style.pixelTop > document.body.offsetHeight + document.body.scrollTop - whichIt.style.pixelHeight - 5) whichIt.style.pixelTop = document.body.offsetHeight + document.body.scrollTop - whichIt.style.pixelHeight - 5;
event.returnValue = false;
} else {
whichIt.moveTo(e.pageX-StalkerTouchedX,e.pageY-StalkerTouchedY);
        if(whichIt.left < 0+self.pageXOffset) whichIt.left = 0+self.pageXOffset;
        if(whichIt.top < 0+self.pageYOffset) whichIt.top = 0+self.pageYOffset;
        if( (whichIt.left + whichIt.clip.width) >= (window.innerWidth+self.pageXOffset-17)) whichIt.left = ((window.innerWidth+self.pageXOffset)-whichIt.clip.width)-17;
        if( (whichIt.top + whichIt.clip.height) >= (window.innerHeight+self.pageYOffset-17)) whichIt.top = ((window.innerHeight+self.pageYOffset)-whichIt.clip.height)-17;
        return false;
}
    return false;
}
function dropIt() {
whichIt = null;
    if(NS) window.releaseEvents (Event.MOUSEMOVE);


    return true;
}
<!-- DRAG DROP CODE -->
if(NS) {
window.captureEvents(Event.MOUSEUP|Event.MOUSEDOWN);
window.onmousedown = grabIt;
  window.onmousemove = moveIt;
window.onmouseup = dropIt;
}
if(IE) {
document.onmousedown = grabIt;
  document.onmousemove = moveIt;
document.onmouseup = dropIt;
}
if(NS || IE) action = window.setInterval("heartBeat()",1);
</SCRIPT>

<BODY>
<DIV id=floater style="Z-INDEX: 1; LEFT: 0px; WIDTH: 754px; POSITION: absolute; TOP: 0px; HEIGHT: 27px; background: #CCCCCC; layer-background-color: #CCCCCC; border: 1px none #000000;"> 
  <table width="100%" border="0">
<tr> 
  <td><div align="center"><font color="#FF0000" face="impact">总在顶端</font></div></td>
</tr>
<tr>
  <td><div align="center"><a href="#top"><font color="#FF0000" face="impact">↑TOP↑</font></a></div></td>
</tr> 
</table>
</DIV>
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
</BODY>
</HTML>


你看这样行不..效果有点差

#8


层能不动么?层上能做下拉菜单么?

#9


把你需要滚动的内容放到<div></div>中,
div标签加上 style="overflow:auto; position:absolute; width:宽px; height:高px;"的属性。