使用JavaScript怎么实现一个选项卡插件-创新互联

使用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'
    });

    第二种方法是现在常用的方法,因为它可以传递很多参数。可以根据需求,设置默认要传递的参数,将这个选项卡插件做的更完善。

    看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联网站建设公司,的支持。


    网站栏目:使用JavaScript怎么实现一个选项卡插件-创新互联
    文章来源:http://pwwzsj.com/article/eoosc.html

    其他资讯