Discuz!X模板代码解析--Header(头文件)
discuz!X模板代码解析--Header(头文件)(转发)
header.html这个文件存储于common文件下,这个大家应该不陌生吧,我是每个DIV为小节来讲,头部的核心div我就不加if语句来讲解!因为代码太多了!我会在最下面给大家总结一下!修改应该注意的地方!
第1行代码:
<!--{subtemplate common/header_common}-->
解释:用于调用common文件下的header_common.html文件,
备注:<!--{subtemplate}-->与<!--{template}--}-->是有区别的,<!--{subtemplate }-->后面的模板文件通常都是被包含在其他模板文件中的子体。这样在解析模板的时候,程序就会判断<!--{subtemplate }-->所引入的模板会被再一次解析一遍然后再和入口模板拼合,组成一个完整的模板。也就是说,如果我们添加的模板是在别的模板中被调用的话我们需要以<!--{subtemplate 模板名称}-->的方式引入进来。
第2-29行代码:
从<meta name="application-name" content="$_G['setting']['bbname']" />开始到以</head>结尾
解释:这里主要放置一些外部文件,其中的代码不多作解释,大家在加的时候请考虑官方的书写规范!
备注:此处虽然不解释太多,但大家还是会用到!如果要加外部调用JS、css请按官方的模板制作规范来书写
第30-186行代码:
从<body>处开始到此文件的最下方
解释:这是首部文件的核心
备注:在修改时请注间要提前备份文件
第32-44行代码:
从<div id="append_parent"></div><div id="ajaxwaitid"></div>处开始到<!--{/if}--><div id="toptb">结尾
解释:此处是整的DIY样式导入、导出及样式修改等,此处代码是隐藏的,
备注:<div id="toptb">是方便你查找才写出!此代码不要修改,在修改模板时也不要漏了!
第32-44行代码:
从代码:<div id="toptb">到</div><!--{if !IS_ROBOT}-->
解释:顶部文件,用于放置导航与dz内部的一些功能,<div>右处内容</div>,<div>左处内容</div>
备注:在后台=》界面=》顶部导航。可以设置。
第70-78行代码:
view plaincopyprint?
<!--{if !IS_ROBOT}-->
<!--{if $_G['uid'] && !emptyempty($_G['style']['extstyle'])}-->
<div id="sslct_menu" class="cl p_pop" style="display: none;">
<!--{if !$_G}--><span class="sslct_btn" title="{lang default}"><i></i></span><!--{/if}-->
<!--{loop $_G['style']['extstyle'] $extstyle}-->
<span class="sslct_btn" title="$extstyle"><i style='background:$extstyle'></i></span>
<!--{/loop}-->
</div>
<!--{/if}-->
解释:此处是拓展色的切换的菜单。
备注:如里不需要可以删除。
第80-96行代码:
view plaincopyprint?
<div id="qmenu_menu" class="p_pop {if !$_G['uid']}blk{/if}" style="display: none;">
<!--{if $_G['uid']}-->
<ul>
<!--{loop $_G['setting']['mynavs'] $nav}-->
<!--{if $nav['available'] && (!$nav['level'] || ($nav['level'] == 1 && $_G['uid']) || ($nav['level'] == 2 && $_G['adminid'] > 0) || ($nav['level'] == 3 && $_G['adminid'] == 1))}-->
<li>$nav</li>
<!--{/if}-->
<!--{/loop}-->
</ul>
<!--{else}-->
<div class="ptm pbw hm">
{lang my_nav_login}
</div>
<!--{/if}-->
</div>
<!--{/if}-->
解释:此处是快捷导航弹出的菜单,里面用到了<!--{if $_G['uid']}-->语句进行判断,意思是只有会员才可以浏览此处内容,循环我就不多讲了哈。
备注:<!--{if $_G['uid']}-->语句可以用到很多地方,自己在做模板的时候,可能会用到!
第97行代码:
1
<!--{ad/headerbanner/wp a_h}-->
解释:头部的广告代码。
备注:可以在后台=》运营=站内广告添加。
第98-184行代码:
从<div id="hd">到 </div><!--{/if}-->
解释:头部的核心文件。
备注:下面是头部核心的DIV指引。
view plaincopyprint?
<div id="hd">
<div class="wp">
<div class="hdc cl">
<h2>logo</h2>---------------------------------->logo
<div id="um">
<div class="avt y">头像</div>-----------------------------头像
<p>
<!--{hook/global_usernav_extra1}-->------------------------------------>插件嵌入点1
<!--{hook/global_usernav_extra2}-->--------------------------------->插件嵌入点2
个人信息---------------------------------------->个人信息
</p>
<p>
<!--{hook/global_usernav_extra3}-->--------------------------->插件嵌入点3
个人信息---------------------------------------->个人信息
</p>
</div>
<!--{template member/login_simple}-->----- > 登录框(此处调用member/login_simple.html文件) </div>
<div id="nv">
<a href="javascript:;" id="qmenu" >快捷导航</a>-------------->快捷导航
<ul>
<li>栏目导航</li>--------------------------------->栏目导航
</ul>
</div>
<ul class="p_pop h_pop" id="plugin_menu" style="display: none">
二级导航菜单样式------------------------------------------------------>二级导航菜单样式
</ul>
< div id="mu" class="cl">
二级导航横排>------------->二级导航横排样式
</div>
<!--{ad/subnavbanner/a_mu}-->------------------------->头部广告(后台站点广告处可以添加)
<!--{subtemplate common/pubsearchform}-->-------->搜索(此处调用common/pubsearchform文件) </div>
</div><!--{hook/global_header}-->插件嵌入点
页:
[1]