十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
使用JavaScript怎么实现一个选项卡插件?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
专注于为中小企业提供成都做网站、网站设计、外贸营销网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业左云免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了超过千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。实现插件的几个注意点:
(1)定义一个固定的html结构,比如选项卡的标题的标签为为li,每个选项卡的内容的标签为div等等;
(2)选中时的样式提前确定;
(3)好先用简单的JS实现选项卡的功能,再改为插件的模式。
html结构如下:
- 编程
- 读书
- 运动
编程使我快乐读书使我幸福运动使我健康
先用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' });
第二种方法是现在常用的方法,因为它可以传递很多参数。可以根据需求,设置默认要传递的参数,将这个选项卡插件做的更完善。
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联网站建设公司,的支持。