常州五颜六色网络技术有限公司 -> 网站建设 -> 网页中多层效果的灵活使用 登录 -> 注册 -> 回复主题 -> 发表主题

阿七 2006-04-04 09:10
动态的网页技术(DHTM)已经非常普及,本文强力向大家推荐一段完整并且是经典的网页多层代码,适用于IE及NETSCAPE游览器,可实现完善的二层网页功能,具体代码请见面文后程序。 Q"|kW[Sg  
/Y[o=Uyl  
  该段代码功能:打开该网页文件之后,将在正常的网页之上,浮动另外一层网页内容,可用鼠标随意移动第二层网页在第一层上的位置,并且当屏幕滚动时,第二图层可始终保持同第一图层的相对位置,效果非常好。 |Vwc/9`t]>  
oY%"2PW1B  
  适用场合:有了这段代码,你可以对很多原有的网页进行改造,使游览者更为方便,比如可用于留言簿,第一层放置留言内容,浮动的第二层放置留言表单,这样游览留言操作和观察留言内容可在同一页面完成,并且无论屏幕滚动到什么位置,留言表单始终出现在屏幕之上,这无疑是最方便的留言系统工作方式。再比如可做为一般网页的导航条,有很多人为了编制美观的页面而放弃使用分栏导航页面方式,而使用整个页面,这样的页面每进入到一个分栏目,都要重新调入整个页面。有了这项技术,可以在原完整的页面之上,浮动一层导航菜单,即方便了导航又保持了页面的完整。另外也可以在某些页面之上浮动一个特定的图像或其它页面内容,等等,总之,这种技术应用非常广泛。 9G#8 %[W  
DVl[t8K!  
 代码说明:代码段一可放置在网页的文件头处,即段。代码段二为正常的网页内容,即第一层的代码内容。第三段为第二层网页的代码段,即浮动的网页内容。代码段四为必要的控制代码,可放置在网页的最后处。灵活使用:下面的代码是完整的网页文件代码,把代码段二和代码段三换成你自己所需要的内容就可以了,但由于本网页文件涉及两个网页的制作过程,可能制作起来相当费力,并且很多网页制作工具不支持这一功能,用低级的网页工具存盘后将失去浮动效果,所以对于这样的网页最好的维护方法是分页维护,即分别编制两个完整的网页内容,之后按要求合并在一个网页文件内即可。这样向你介绍一种最可取的方法,众所周知,现在的网页技术可以实现在一个网页内调用其它网页的功能,即所谓的画中画功能,所以完全可以把代码二和代码三换成固定的调用其它网页的固定代码,之后只需要对这两个单独的页维护就可以了。具体可用下面的代码替换代码二和三: |'c4er/;#  
e(~'pk"mZ  
ILAYER id="ad1" visibility="hidden" height="60"> 6!+X.+  
</ILAYER> U.RW4df%E  
<NOLAYER> \ I^nx+l  
<IFRAME SRC="h1.htm" width="100%" height="60" marginwidth="0" marginheight="0" hspace="0" vspace="0" frameborder="0" scrolling="no">  O[IR|  
</IFRAME> 其中SRC:用于指定打开的网页地址; 19F ;oFp  
width:该表格占用的宽度; K lli$40  
height:该表格点用的高度; "[*S?QO(L  
marginwidth:网页内容在表格右侧的预留宽度; =Y &9 qt  
marginheight:网页内容在表格顶部预留的高度; N^ h |h  
hspace:网页右上角的横坐标; t/KcXM  
vspace:网页右上角的纵坐标; d&[iEU  
frameborder:是否显示边缘; @sw9A 93A  
scrolling:是否出现滚动条; _BG8/"h32  
具体使用时把h1.htm分别换成不同的网页文件名。 VY/|WD~"CW  
完成的网页文件代码如下: 48tcgFg[  
<html> `]`=]*d  
<head> ;w`s z.  
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> m$fQ`XzU  
//代码段一 qDnCn H  
<style type="text/css"><!-- i`[#W(m  
#floater {position: absolute;left: 500;top: 146;width: 125;visibility: visible;z-index: 10;} c ]>DI&$;J  
--> |7 &|>  
</style> (M ]XNn  
//代码段一结束 AL>c:K)qO  
<title>浮动层</title> gtD   
</head> w &p~0cA~  
//代码段二(第一层内容,目前为空) P+Wm9xR2d  
<body bgcolor="#FFFFFF"> h&lyxYZ+T$  
<BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR> 7MY)\aH  
//代码段二结束 [6AHaOhR'  
//代码段三(浮动层内容,目前为一简单表格) M_k`%o  
<div ID="floater" style="left: 0px; top: 1px"> JC=dYP}  
<table border="1" cellpadding="0" cellspacing="0" b -PSm=`  
bgcolor="#25A78D" bordercolordark="#00FFFF" O!;H}{[dg  
bordercolorlight="#000000"> N83!C=X'  
<tr> 4~!Eje!  
<td>111<a href="file:///G:/C/NEW/dhtml2.htm">1111</a></td> c$9sF@K?  
<td>2222222</td> WFouoXlG0  
</tr> PPEq6}  
</table> +A@m9  
</div> C 8N%X2R  
//代码段三结束 z. 'Fv7  
//代码段四 C>^,*7dS  
<script LANGUAGE="JavaScript"> kP@H G<~  
self.onError=null; nE_Cuc>K\  
currentX = currentY = 0; kd yAl,  
whichIt = null; rWA6X DM7  
lastScrollX = 0; lastScrollY = 0; 80C(H!^  
NS = (document.layers) ? 1 : 0; 0Z"s_r}h  
IE = (document.all) ? 1: 0; u^t$ cLIZ  
<!-- STALKER CODE --> D&/I1=\(  
function heartBeat() { \wYc1M@7V  
if(IE) { diffY = document.body.scrollTop; diffX = document.body.scrollLeft; } q]CeD   
if(NS) { diffY = self.pageYOffset; diffX = self.pageXOffset; } LT/mb2  
if(diffY != lastScrollY) { 6ZcXS  
percent = .1 * (diffY - lastScrollY); ! D$Ooamq  
if(percent > 0) percent = Math.ceil(percent); hUh+JW  
else percent = Math.floor(percent); h h"h j  
if(IE) document.all.floater.style.pixelTop += percent; e4DMO*6  
if(NS) document.floater.top += percent; M ,`w A  
lastScrollY = lastScrollY + percent; } ?E6^!4=,  
if(diffX != lastScrollX) { ;r.EC}>m  
percent = .1 * (diffX - lastScrollX); -jB3L:  
if(percent > 0) percent = Math.ceil(percent); ];1R&:t  
else percent = Math.floor(percent); cL G6(<L  
if(IE) document.all.floater.style.pixelLeft += percent; E;9>ePd@  
if(NS) document.floater.left += percent; 3@_Elu  
lastScrollX = lastScrollX + percent;}} L 0L2Ns  
<!-- /STALKER CODE --> <.bRf  
<!-- DRAG DROP CODE --> Xh F _]  
function checkFocus(x,y) { XRxj  W  
stalkerx = document.floater.pageX; KnGTcoXg_  
stalkery = document.floater.pageY; ?2 f_aY ;  
stalkerwidth = document.floater.clip.width; ^AL2H'  
stalkerheight = document.floater.clip.height; pvF-Y9Xb  
if( (x > stalkerx && x < (stalkerx+stalkerwidth)) && (y > stalkery && y < (stalkery+stalkerheight))) return true; BhkoSkr  
else return false; } [ c~kF+8  
function grabIt(e) { aJzLrX  
if(IE) {whichIt = event.srcElement; !Ms[eB  
while (whichIt.id.indexOf("floater") == -1) { /TV= $gB`  
whichIt = whichIt.parentElement; e2cP *J  
if (whichIt == null) { return true; } } `XKVr  
whichIt.style.pixelLeft = whichIt.offsetLeft; ) #+^ sAO  
whichIt.style.pixelTop = whichIt.offsetTop; BUsV|e \  
currentX = (event.clientX + document.body.scrollLeft); h&;t.Gdf  
currentY = (event.clientY + document.body.scrollTop); } else { G^;>8 r  
window.captureEvents(Event.MOUSEMOVE); Kr-G{b_Pp  
if(checkFocus (e.pageX,e.pageY)) { ba @ctkCW  
whichIt = document.floater; 4a''Mi`u  
StalkerTouchedX = e.pageX-document.floater.pageX; -LW[7s$  
StalkerTouchedY = e.pageY-document.floater.pageY; } } Ii &7rdoxe  
return true;}  Vzl^Ka'  
function moveIt(e) { 8gy_Yj&{P  
if (whichIt == null) { return false; } IzLQhDJ1  
if(IE) { Ul+Mo&y-  
newX = (event.clientX + document.body.scrollLeft); 5d\q-d  
newY = (event.clientY + document.body.scrollTop); )B$;Vs] @i  
distanceX = (newX - currentX); distanceY = (newY - currentY); ~j9O$s~)  
currentX = newX; currentY = newY; EYX$pz(x;  
whichIt.style.pixelLeft += distanceX; ?OlV"zK  
whichIt.style.pixelTop += distanceY; $F'>yop2b  
if(whichIt.style.pixelTop < document.body.scrollTop) whichIt.style.pixelTop = document.body.scrollTop; Np+&t}  
if(whichIt.style.pixelLeft < document.body.scrollLeft) whichIt.style.pixelLeft = document.body.scrollLeft; 36.N>G,  
if(whichIt.style.pixelLeft > document.body.offsetWidth - document.body.scrollLeft - whichIt.style.pixelWidth - 20) whichIt.style.pixelLeft = document.body.offsetWidth - whichIt.style.pixelWidth - 20; i0jBZW"_1$  
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; GH1"xR4!  
event.returnValue = false; fw6UhG  
} else { Q[F}r`  
whichIt.moveTo(e.pageX-StalkerTouchedX,e.pageY-StalkerTouchedY);  rl2&^N  
if(whichIt.left < 0+self.pageXOffset) whichIt.left = 0+self.pageXOffset; UMl#D >:C<  
if(whichIt.top < 0+self.pageYOffset) whichIt.top = 0+self.pageYOffset; \*f;Xaa  
if( (whichIt.left + whichIt.clip.width) >= (window.innerWidth+ self.pageXOffset-17)) whichIt.left = ((window.innerWidth+self.pageXOffset)-whichIt.clip.width)-17; : j }fC8'  
if( (whichIt.top + whichIt.clip.height) >= (window.innerHeight+ self.pageYOffset-17)) whichIt.top = ((window.innerHeight+self.pageYOffset)-whichIt.clip.height)-17; 03E4cYxt5  
return false; } return false; } Z_1U 9 +,  
function dropIt() { I`KQ|h0%  
whichIt = null; o6 E!IX+  
if(NS) window.releaseEvents (Event.MOUSEMOVE); ^j#rZ;uc   
return true; } 8{`?= &%6  
<!-- DRAG DROP CODE --> ,1OyN]f3  
if(NS) { om?-WJI  
window.captureEvents(Event.MOUSEUP|Event.MOUSEDOWN); Mi'8 ~J  
window.onmousedown = grabIt; ] e. JNo  
window.onmousemove = moveIt; mKo C.J  
window.onmouseup = dropIt; } >SPh2[f  
if(IE) { ;qHOOT  
document.onmousedown = grabIt; #Zrlp.M4  
document.onmousemove = moveIt; mU}F!J#6  
document.onmouseup = dropIt; } {43>m)8+  
if(NS || IE) action = window.setInterval("heartBeat()",1); b[V^86X^  
</script> K2%w0ohC  
//代码段四结束 |$5[(6T|  
</body> ME'|saP  
</html>


查看完整版本: [-- 网页中多层效果的灵活使用 --] [-- top --]

51La

Copyright © 2005-2014 5y6s Inc. 苏ICP备05001866号 Powered by PHPWind 5.0.1
Time 0.010344 second(s),query:3 Gzip enabled