JS实现选项卡插件有什么办法?哪些问题要注意?
Admin 2021-05-24 群英技术资讯 988 次浏览
我们平常在浏览一些网站的时候,经常能看到选项卡展示功能,其好处就是节约页面空间,我们只要点击不同的区域,就能展现不同的内容,这样能比较合理的展示内容。那么JS是怎样实现选项卡插件的呢?
实现插件的几个注意点:
(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'
});
第二种方法是现在常用的方法,因为它可以传递很多参数。可以根据需求,设置默认要传递的参数,将这个选项卡插件做的更完善。
文本主要介绍了JS实现选项卡插件的两种方法,上述有具体代码,需要的朋友可以参考学习,希望能帮助到大家,更多JS选项卡插件的内容,大家可以关注相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文给大家介绍的是JS事件对象的内容,那JS中“事件对象”,到底是什么意思的?其实JS事件对象并不难理解,接下来我们就详细的了解一下JS事件对象,及事件对象中的属性和方法,感兴趣的朋友就继续往下看吧。
目录1. 自定义组件官方文档1.1 创建自定义组件1.1.1 声明组件1.1.2 编辑组件1.2 使用自定义组件1.3 页面向自定义组件传递数据(父传子)1.4 组件将事件传给页面(子传父)1. 自定义组件小程序允许我们使用自定义组件的方式来构建页面。官方文档自定义组件是不是用的微信的组件感觉很爽啊,如果不够用怎么办?
某些情况下需要在典型数据流外强制修改子代。要修改的子代可以是 React 组件实例,也可以是 DOM 元素。这时就要用到refs来操作DOM,本文详细的介绍一下使用,感兴趣的可以了解一下
这篇文章主要为大家介绍了vue原理Compile之optimize标记静态节点源码示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
vue怎样做点击展开收起的功能?在很多网站上都能看到点击展开收起的功能,点击展开收起的效果能让网页设计更简洁好看,也是比较使用的,因此这篇文章就给大家分享一下vue实现点击展开收起效果的方法。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008