时间:2021-05-26
本文实例为大家分享了JS实现选项卡插件的2种写法,供大家参考,具体内容如下
实现插件的几个注意点:
(1)定义一个固定的html结构,比如选项卡的标题的标签为为li,每个选项卡的内容的标签为div等等;
(2)选中时的样式提前确定;
(3)最好先用简单的JS实现选项卡的功能,再改为插件的模式。
html结构如下:
<style> * { margin: 0; padding: 0; } ul { list-style: none; } #tabBox { box-sizing: border-box; margin: 20px auto; width: 500px; } .navBox { display: flex; position: relative; top: 1px; } .navBox li { box-sizing: border-box; margin-right: 10px; padding: 0 10px; line-height: 35px; border: 1px solid #999; cursor: pointer; } .navBox li.active { border-bottom-color: #FFF; } #tabBox>div { display: none; box-sizing: border-box; padding: 10px; height: 150px; border: 1px solid #999; } #tabBox>div.active { display: block; } </style> <div id="tabBox"> <ul class="navBox"> <li class="active">编程</li> <li>读书</li> <li>运动</li> </ul> <div class="active">编程使我快乐</div> <div>读书使我幸福</div> <div>运动使我健康</div></div>先用JS实现选项卡的功能:
let len = liList.length; for(let i = 0; i < len; i++) { liList[i].index = i; liList[i].onclick = function() { for(let j = 0; j < len; j++) { if(j === this.index) { liList[j].className = 'active'; contentList[j].className = 'active'; } else{ liList[j].className = ''; contentList[j].className = ''; } } };}实现插件的第一种方法:jQuery
利用$.fn.extend方法,在jQuery上扩展一个选项卡功能的方法:
(function($){ function clickLi() { let $this = this, $navBox = $this.find('.navBox'), $liList = $navBox.find('li'), $contentList = $this.find('div'); $liList.click(function(){ let $this = $(this), index = $this.index(); $this.addClass('active').siblings().removeClass('active'); $contentList.eq(index).addClass('active').siblings().removeClass('active'); }); } $.fn.extend({ tabClick: clickLi });})(jQuery);使用方法:
let $tabBox = $('#tabBox');$tabBox.tabClick();实现插件的第二种方法:class
利用ES6中的class类,创建一个选项卡类Tab,并添加属性和方法,并且可以多参数传递实现选项卡:
(function(){ class Tab { constructor(selector, options) { // 处理第一个参数 if(!selector) throw new ReferenceError('The first selector parameter must be passed~~'); if(typeof selector === 'string') this.container = document.querySelector(selector); else if(selector.nodeType) this.container = selector; this.initialParams(options); this.navBox = this.container.querySelector('.navBox'), this.liList = this.navBox.querySelectorAll('li'), this.contentList = this.container.querySelectorAll('div'), this.count = this.liList.length; this.change(); this.handleLi(); } // 初始化参数 initialParams(options) { let _default = { showIndex: 0, triggerEvent: 'click' }; for(let key in options) { if (!options.hasOwnProperty(key)) break; _default[key] = options[key]; } // 把信息挂载到实例上 for (let key in _default) { if (!_default.hasOwnProperty(key)) break; this[key] = _default[key]; } } // 切换标题 change() { [].forEach.call(this.liList, (item, index) => { if(index === this.showIndex) { this.liList[index].className = 'active'; this.contentList[index].className = 'active'; return; } this.liList[index].className = ''; this.contentList[index].className = ''; }); } // 绑定标题对应的事件 handleLi() { [].forEach.call(this.liList, (item, index) => { item.addEventListener(this.triggerEvent, () => { this.showIndex = index; this.change(); }); }); } } window.Tab = Tab;})();使用方法:
new Tab('#tabBox', { showIndex: 2, triggerEvent: 'mouseenter'});第二种方法是现在常用的方法,因为它可以传递很多参数。可以根据需求,设置默认要传递的参数,将这个选项卡插件做的更完善。
如果大家还想深入学习,可以点击两个精彩的专题:javascript选项卡操作方法汇总 jquery选项卡操作方法汇总
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
分别利用javascript的源码和jQuery来实现一个简单的选项卡,对比各自的步骤。jQuery实例—选项卡的简单实现(js源码和jQuery)div{di
本文实例讲述了JS实现完全语义化的网页选项卡效果代码。分享给大家供大家参考。具体如下:这是一款完全语义化的JS网页选项卡,包括了两种用法,一种是点击式,另一种是
本文实例讲述了jQuery网页选项卡插件rTabs用法。分享给大家供大家参考。具体如下:这里介绍jQuery网页选项卡插件rTabs用法,一共演示了4种TAB选
效果图:动感效果的TAB选项卡jquery插件复制代码代码如下:ul>li[class!='on']>a").click(function(){returnfa
本文实例讲述了js实现的EasyTabs选项卡用法。分享给大家供大家参考。具体如下:本网页选项卡是EasyTabs选项卡插件中的一个演示实例代码,是一个最简单的