ecshop简单三部实现导航分类二级菜单
1.在page_header.lbi对应的位置(你想显示导航的位置)插入
(注意下面的"themes/模板名称/util.php"中的"模板名称"改成你模板文件夹的名称)
- <?php
- require_once("themes/模板名称/util.php");
- ?>
- <div class="header-menu">
- <p {if $navigator_list.config.index eq 1} class="cur" {/if}><a href="../index.php">{$lang.home}</a></p>
- <ul>
- <!-- {foreach name=nav_middle_list from=$navigator_list.middle item=nav} -->
- <li onMouseOver="sw_nav(this,1);" onMouseOut="sw_nav(this,0);" {if $nav.active eq 1} class="curs"{/if}>
- <a href="{$nav.url}" {if $nav.opennew eq 1}target="_blank" {/if}>{$nav.name}</a>
- <?php
- $subcates = get_subcate_byurl($GLOBALS['smarty']->_var['nav']['url']);
- if($subcates!=false)
- {
- if(count($subcates)>0)
- {
- echo "<div class='sub_nav'>";
- if($subcates)
- {
- foreach($subcates as $cate)
- {
- echo "<a href='".$cate['url']."' class='level_1'>".$cate['name']."</a>";
- }
- }
- echo "</div><iframe frameborder='0' scrolling='no' class='nomask'></iframe>";
- }
- }
- ?>
- </li>
- <!-- {/foreach} -->
- </ul>
- <script type="text/javascript">
- //初始化主菜单
- function sw_nav(obj,tag)
- {
- var subdivs = obj.getElementsByTagName("DIV");
- var ifs = obj.getElementsByTagName("IFRAME");
- if(subdivs.length>0)
- {
- if(tag==1)
- {
- subdivs[0].style.display = "block";
- ifs[0].style.display = "block";
- }
- else
- {
- subdivs[0].style.display = "none";
- ifs[0].style.display = "none";
- }
- }
- }
- </script>
- </div>
2.在CSS文件中插入
- .header-menu p{ float:left;padding:1px 12px 1px 0;margin-top:-2px;}
- .header-menu ul li{float:left;padding:1px 12px 1px 12px;margin-top:-2px;}
- .header-menu ul li a,.header-menu p a{color: #333;display:block;}
- .header-menu ul li a:hover,.header-menu p a:hover{color:#888;}
- .header-menu ul li.curs{background:#999;}
- .header-menu ul li.curs a{color:#fff;}
- .sub_nav{ background:#999;width:110px; position:absolute; z-index:5003; display:none;margin-left:-12px;}
- .nomask{ background:#fff; width:110px; height:50px; position:absolute; z-index:5002;display:none;margin-left:-12px;}
- .sub_nav a.level_1{ display:block;color:#fff;padding:6px 6px 6px 13px;font:11px Tahoma,Verdana,PMingLiU,Arial;border-bottom:1px dotted #D1D1D1;*border-bottom:1px dotted #D1D1D1 !important;*border-bottom:1px solid #A8A8A8;}
- .sub_nav a.level_1:hover{color:#fff;background:#55B46C;text-decoration:none;}
3.把以下代码编辑成(util.php)解压出来拷贝到模板目录下
- <?php
- /**
- * 通过传入参数的url判断是否为目录分类,从而获取子菜单
- *
- * @param string $url
- */
- function get_subcate_byurl($url)
- {
- $rs = strpos($url,"category");
- if($rs!==false)
- {
- preg_match("/\d+/i",$url,$matches);
- $cid = $matches[0];
- $cat_arr = array();
- $sql = "select * from ".$GLOBALS['ecs']->table('category')." where parent_id=".$cid." and is_show=1";
- $res = $GLOBALS['db']->getAll($sql);
- foreach($res as $idx => $row)
- {
- $cat_arr[$idx]['id'] = $row['cat_id'];
- $cat_arr[$idx]['name'] = $row['cat_name'];
- $cat_arr[$idx]['url'] = build_uri('category', array('cid' => $row['cat_id']), $row['cat_name']);
- $cat_arr[$idx]['children'] = get_clild_list($row['cat_id']);
- }
- return $cat_arr;
- }
- else
- {
- return false;
- }
- }
- function get_clild_list($pid)
- {
- //开始获取子分类
- $sql_sub = "select * from ".$GLOBALS['ecs']->table('category')." where parent_id=".$pid." and is_show=1";
- $subres = $GLOBALS['db']->getAll($sql_sub);
- if($subres)
- {
- foreach ($subres as $sidx => $subrow)
- {
- $children[$sidx]['id']=$subrow['cat_id'];
- $children[$sidx]['name']=$subrow['cat_name'];
- $children[$sidx]['url']=build_uri('category', array('cid' => $subrow['cat_id']), $subrow['cat_name']);
- }
- }
- else
- {
- $children = null;
- }
- return $children;
- }
- ?>
ecshop简单三部实现导航分类二级菜单的更多相关文章
- Bootstrap系列 -- 40. 导航条二级菜单
在导航条中添加二级菜单也非常简单 <div class="navbar navbar-default" role="navigation"> < ...
- dedecms织梦导航栏二级菜单的实现方法
dede导航下拉菜单,一级栏目增加二级下拉菜单 使用dedecms5.6——5.7 将这段代码贴到templets\default\head.htm文件里<!-- //二级子类下拉菜单,考虑 ...
- PHPCMS v9 导航显示二级菜单,显示相邻栏目,内容页显示二级栏目
导航显示二级栏目 <div class="menu">{pc:content action="category" catid="0&quo ...
- 简单仿京东导航下拉菜单 javascript
<html xmlns="http://www.w3.org/1999/xhtml"><head runat="server"> ...
- 兼容ie7的导航下拉菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 纯CSS实现二级导航下拉菜单--css的简单应用
思想:使用css的display属性控制二级下拉菜单的显示与否.当鼠标移动到一级导航菜单的li标签时,显示二级导航菜单的ul标签.由于实现起来比较简单,所以在这里直接给出了参考代码. 1.纯CSS二级 ...
- 通用方法解决dedecms导航调用二级、三级栏目菜单
博客之前做网站的时候经常会遇到二级菜单.三级菜单.了解dede的人都知道从5.5版本开始都有二级菜单的调用方法了,网上也有不少的教程文章.不过这个调用需要修改dede源码的二级菜单样式.个人感觉不是很 ...
- JS实现的简单横向伸展二级菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- bootstrap学习笔记之为导航条添加标题、二级菜单及状态 http://www.imooc.com/code/3120
为导航条添加标题.二级菜单及状态 加入导航条标题 在Web页面制作中,常常在菜单前面都会有一个标题(文字字号比其它文字稍大一些),其实在Bootstrap框架也为大家做了这方面考虑,其通过" ...
随机推荐
- cocos2dx 3.x以上版本搭建Mac环境(百分百可行)
近期由于工作的原因,有机会接触了游戏行业,说实话,本人学程序最原始的初衷就是想做游戏,于是就创建了一篇cocos2d-x的分类来记录我在学习cocos2d-x的成长过程. 首先第一篇,想学cocos2 ...
- 使用awk统计字段重复实践
awk awk是一种规格化文件的分析工具, 主要处理对象类似数据库导出的条目文本文件, 其中一行,就对应一个记录,每个记录包含若干个字段. 类似这种文本: [root@www ~]# last -n ...
- js随机更换
如果想实现“随机”切换图像,那么我们要使用到几个Math()对象 第一个是random()函数,函数的功能是产生随机数,如果书写为 var a=Math.random() 那么所产生的随机数是0-1( ...
- HBase -- 基于HDFS的开源分布式NoSQL数据库
HBase(Hadoop Database)是一个高可靠性.高性能.面向列.可伸缩的分布式存储系统,我们可以利用HBase技术在廉价的PC上搭建起大规模结构化存储集群.同Google的Bigtable ...
- malloc心得
使用malloc时,要有一种在内存中随机分配一块内存的思想,然后再把分配好的内存的首地址返回来.
- android waiting for debugger
在Studio开发环境中,使用真机开发经常会出现waiting for debugger,卡死不动了,让人很崩溃啊,现在我就总结下几种解决方法,希望能帮到出现同样情况的朋友! 问题出现及解决办法: 多 ...
- sql 表连接 join
inner join 和 join 的 区别 inner join 是内连接 ,查询出两边 都有的数据 join 是交叉 连接, 假设集合A={a, b},集合B={0, 1, 2},则两个集 ...
- 安装Elasticsearch,Logstash,Kibana(5.0.1-mac版)
安装Elasticsearch 1.下载https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-5.0.1.tar.gz包 ...
- System Hold, Fix Manager before resetting counters
程序pending http://www.askmaclean.com/archives/2011/11 http://blog.itpub.net/35489/viewspace-717132/ 1 ...
- 夺命雷公狗ThinkPHP项目之----企业网站24之网站前台列表页面包屑导航的显示
我们做面包屑导航的原理其实也是很简单的,我们的思路是: 首先找到该分类的id ,我们可以通过大 I来进行获取得到: 然后通过 大 D 方法让数据进入model层里面进行循环迭代查询, 当然,测试时候发 ...