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简单三部实现导航分类二级菜单相关推荐
- 简单实现CSS导航栏二级菜单从上往下平滑滑下弹出效果
页面样式如下: html: <li><div class="nav-tab">技术分析</div><ul class="nav- ...
- Axure RP9——【导航栏二级菜单的展开效果】
导航栏二级菜单的展开效果 Navigation Bar · secondary menu Here's how I want things to unfold. 目录 导航栏二级菜单的展开效果 Nav ...
- html 中怎么写二级导航,html二级菜单导航栏成品
html 高级二级导航菜单 代码如下: #menu { width: 600px; font-family: Arial; font-size: 15px; } #menu ul { display: ...
- html+css 实现导航栏二级菜单——气泡框
页面效果展示: 代码实现: HTML部分 <!DOCTYPE html> <html lang="en"><head><meta char ...
- 第四篇 bonus:js代码实现网页导航二级菜单
第四篇 bonus:js代码实现网页导航二级菜单 由于小猪蹄子说想学习一些和爬虫相关的东西,所以我让她去看看requests这个库,非常的人性化,可以非常方便的实现常用的爬虫功能.但是小猪蹄子看了以后 ...
- 前端入门css学习笔记(十七)-----二级菜单
二级菜单的方法就是在一个<ul><li>中再嵌套一个<ul><li> 如下: <ul class="box"><l ...
- css导航栏(二级菜单)
效果: <!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8& ...
- html二级菜单的自动宽度,如何使用CSS控制二级导航菜单宽度?_html/css_WEB-ITnose
New Document 首页 新闻国际新闻 国内新闻 体育新闻 财经股票市场 证券行情 基金保险 联系我们 回复讨论(解决方案) .menu li ul a{ display:block; font ...
- css二级菜单的隐藏与显示_具有二级菜单的导航案例
下图为具有二级菜单的导航效果,鼠标悬浮在"服装"菜单时出现如图所示的二级菜单效果. 鼠标悬浮于二级菜单效果如下图所示: 注:鼠标悬浮于菜单时,二级菜单背景颜色为渐变,渐变颜色值为# ...
最新文章
- ICRA 2022 | CaTGrasp: 从模拟器中学习类别级的任务相关的抓取姿态
- pytorch 打印模型参数
- prometheus+grafana+pushgateway+node-exporter+consul搭建监控系统
- java asm 中文文档_Java ASM3学习(3)
- bash的一些小技巧
- 一文玩转 EhCache 缓存框架!
- C Runtime Library来历, API, MFC, ATL关系
- 关键字nullable,nonnull,null_resettable,_Null_unspecified详解
- 【BZOJ-1097】旅游景点atr SPFA + 状压DP
- 鸿蒙系统微信红包,鸿蒙道红包版
- Scarlett~スカーレット 有感,新的价值观
- 微信提示在客户端提交验证_微信中怎么查看我发送的好友验证请求?
- 马科维茨投资组合理论(均方模型)学习笔记——基于Matlab(一)
- SysML实践指南第二版(中文翻译:刘亚龙)第三章 SysML介绍
- 恢复rm -rf 的数据
- 配置H3C设备无线AP多vlan步骤
- WinUSB安装以及与Linux通讯
- Android 通过 WebView 请求下载 APK
- nokogiri 足球比赛数据
- slice 和 splice的区别是什么?