类似于上面这种导航,我在thinkphp中利用其模板继承的原理定义了一个base.html的文件,其中包含通用的header头部、nav导航、footer底部,其它的html文件会继承该base.html模板。
请问我在访问其它页面的时候如何高亮当前页面对应的导航?
如上图,当我访问实战页面的时候,如何高亮当前页面对应的导航,如果该导航为多级导航?
当我访问对应主导航的下级导航时,如何正确的高亮对应页面的子导航上的主导航?
在线等,希望各位朋友能指点下疑惑。
回复内容:
类似于上面这种导航,我在thinkphp中利用其模板继承的原理定义了一个base.html的文件,其中包含通用的header头部、nav导航、footer底部,其它的html文件会继承该base.html模板。
请问我在访问其它页面的时候如何高亮当前页面对应的导航?
如上图,当我访问实战页面的时候,如何高亮当前页面对应的导航,如果该导航为多级导航?
当我访问对应主导航的下级导航时,如何正确的高亮对应页面的子导航上的主导航?
在线等,希望各位朋友能指点下疑惑。
这个貌似属于js控制的吧,而且楼主也做了nav导航了,thinkphp 当中用它的标签 ,
加载页面后,判断下当前的url
,是否是以header.html
中的a
标签的href
开头,
例如当前url:xxx.com/home/xxxx => a href="xxx.com/home"
,匹配后添加class active
高亮
你应该是因为同一layout页面需要包含不同页面而不知如何为每个页面显示它所属的导航而困扰吧?
如果是的话,那么js方面,你可以从url入手,分析url规则,然后高亮菜单
PHP的话,url或者控制器方法都可以,也是判断,高亮的话,配合js或者css都可以实现
总的来说,你需要记住的就是,根据访问的形式不同,剥离开来,进行判断,然后高亮,就可以了。
方法1,可以用js控制,在每个包含这个base的页面中写js,特意没用ES6,方便你用。
<code>var nav = Array.prototype.slice.call(document.querySelectorAll('#nav a')); var currentPath = location.pathname; nav.forEach(function(a) { if(a.pathname === currentPath) a.classList.add('active'); });</code>
方法2,用php。思路一样,获取当前请求的页面的url,然后匹配路径,不过php那一套都一年多不用了,忘记咋写了。。。。
个人一般在_initialize中:
<code>$this->assign("cur_nav","home");</code>
<code><li name="cur_nav" value="company">class="active" ><a href="%7B:U('/clist')%7D">装修公司</a> </li> <li name="cur_nav" value="demand">class="active" ><a href="%7B:U('/dlist')%7D">装修招标</a> </li></code>
类似于这种,然后模板中判断curr_nav的值。
如果导航简单的话就直接通过模块、控制器、操作组合上判断
js也能判断只是感觉页面会闪动不爽!

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

WebStorm Mac版
好用的JavaScript开发工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

SublimeText3 英文版
推荐:为Win版本,支持代码提示!