大型网站的头尾部分处理

本文探讨了大型网站如何通过将头部、导航和尾部做成静态公用文件以提高代码重用性和降低维护成本。文章详细介绍了不同用户状态下的头部和导航栏变化,并提出使用JS读取Cookie来实现动态展示的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一个网站各个页面的相同之处莫过于头部、导航、尾部,每一个程序手都知道代码重用性的好处。如果我们把这些文件都做成公用文件,那么将大大节省了维护成本。

大型网站的头尾部分和导航部分一般都会做成静态的公用文件。
尾部文件footer块的内容是关于、联系方式、版权等内容,直接做成静态文件便可。
头部文件header和导航menubar往往有两种状态。用户未登录状态,显示的内容是注册、登录等内容。用户已登录状态,显示内容有“欢迎你,某某”、未读消息数等。还有一些特别的导航链接也不一样,比如“会员中心”的链接,未登录时链到登录页面,而已登录状态则链到会员中心首页。
我们已将这些块做成了静态文件,那么怎么处理这两种状态呢?剩下只能使用js来控制。在登录页面,当验证用户登录成功时向用户电脑写入cookie,比如用户呢称用户ID等信息。如此我们就可以写一段JS读取之前写入的cookie,如果用户信息存在就说明用户已登录,再根据返回的结果以JS动态更改头部文件及导航的内容。这样两种状态就实现了。

另外要说一点,这之中可能会涉及其它一些问题。
大型网站往往有很多二级域名,这些二级域名之间要共用头尾文件,那么就存在了跨域问题。
跨域读取cookie,这个解决办法很简单,只要在写入cookie时设置domain为根域名xxx.com,这样所有的二级域都可访问了,甚至三级域名也行。
这些公用文件一般采用include的包含方式加入到各页面中,但是这种包含只能包含本域名下的文件,那么其它二级域名如何共用一个文件呢?这里又涉及了跨域问题,可以对服务器设置虚拟目录或虚拟路径。比如真实头尾文件存在www.xxx.com/inc下,yy.xxx.com域名下的页面怎么包含www.xxx.com/inc的文件呢?可以在yy.xxx.com下开一个虚拟目录指向www.xxx.com下相应的/inc目录。这样就做成了重用性,改一个www.xxx.com/inc下的文件,所有其它域名/inc下相应文件也随之更新了。
虚拟的办法也可以解决ajax跨域的问题,原理一样。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值