<!--css部分-->

<style>

*{
margin: 0;
padding: 0;
}

ul,li{
list-style: none
}
.tabbox{
width: 600px;
clear: both;
overflow: hidden;
margin: 0 auto;
border: 1px solid #ccc;
}
ul.tabnav{
width: 600px;
height: 30px;
border-bottom: 1px solid #ccc;
}

ul.tabnav li{
width: 198px;
height: 30px;
line-height: 30px;

float: left;

border-right: 1px solid #ccc;
text-align: center;
}

ul.tabnav li.active{
color: red;
}

.tabcontent{
width: 460px;
overflow: hidden;;
padding: 20px;
}

.tabcontent ul li{
float: left;
display: none;
}

.tabcontent ul li.active{
display: block;
}

</style>

<!--HTML 结构-->

<div class="tabbox">
 <ul class="tabnav" id="tabnav">
  <li class="item active">语文</li>
  <li class="item">英语</li>
  <li class="item">数学</li>
</ul>

<div class="tabcontent" id="tabcont">
<ul>
  <li class="item active">语文内容</li>
  <li class="item">英语内容</li>
  <li class="item">数学内容</li>
</ul>
</div>
</div>

<!--javascript-->

function SwitchTab(tabbtn,tabcontent){

var tabNav = document.getElementById(tabbtn);
  var tabcont = document.getElementById(tabcontent);

this.tabNavLi = tabNav.getElementsByTagName('li');
  this.tabcontLi = tabcont.getElementsByTagName("li");

var _this = this;    //保存创建出来的变量tabs;

for(var i=0, len=this.tabNavLi.length; i<len; i++){
      this.tabNavLi[i].index = i;
      this.tabNavLi[i].onclick = function (){
      _this.tabshow(this);   //这里的this 值得是当前点击的选项
    };
  }

}

SwitchTab.prototype.tabshow = function(obj){  //这里的obj 是当前被点击按钮的那个对象
  for(var i=0, len=this.tabNavLi.length; i<len; i++){
    this.tabNavLi[i].className = "";
    this.tabcontLi[i].className = "";
  }

obj.className = "active";
  this.tabcontLi[obj.index].className = "active";
};

window.onload = function(){
  var tabs = new SwitchTab("tabnav","tabcont");
};

</script>

//改写成面向对象最重要的是要注意this 指的是谁。 出现以下两种情况this的值应该怎么保存呢?

1. 当面向对象程序中有计时器的时候

function Aaa() {
  this.a = 10;
  var _this = this;
  setInterval(function(){
    _this.show();    //如果直接使用this,那么这里的this指向的的是window
  },1000);
}

Aaa.prototype.show = function(){
  alert(this.a);
};

window.onload = function() {
  var aaa = new Aaa();
};

2、当面向对象程序中有事件的时候

function Bbb() {
 this.a = 10;
 var _this = this;
 var btn = document.getElementById("btn");

btn.onclick = function() {
  _this.show();  //这里的this指向的是当前对象
 };
}

Bbb.prototype.show = function(){
  alert(this.a);
};

window.onload = function() {
  var bbb = new Bbb();
};

原生javascript 改写的tab选项卡的更多相关文章

  1. JavaScript插件制作-tab选项卡

    JavaScript插件制作练习-鼠标划过选项卡切换图片 <!DOCTYPE html> <html> <head> <meta charset=" ...

  2. 原生js实现tab选项卡里内嵌图片滚动特效代码

    <!DOCTYPE HTML><html lang="en-US"><head><meta charset="UTF-8&quo ...

  3. 原生tab选项卡

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. 可轮播滚动的Tab选项卡

    前段时间有试着搭建个后台主题ui框架,有用到可支持滚动的Tab选项卡,模仿着H+后台主题ui框架中的代码造轮子改造了下,可惜代码在公司,不能把代码外发出来(感觉这样被限制了很多,对于这样的公司没办法, ...

  5. js基础练习一之tab选项卡

    最近在学习前端,当然包括js,css,html什么的,在听课时做的一些小练习,记录下来: 实例一: --Tab选项卡-- <script type="text/javascript&q ...

  6. tab选项卡-jQuery

    上次用原生的js写了个tab选项卡   这次按照一样的思路用jQuery写了一个 ,直接看代码: /*布局*/ <div id="div1"> <input cl ...

  7. react tab选项卡切换

    Tab选项卡切换是个很常见也很简单的小功能,用原生js和jq去写的话可能不到20行代码就搞定so easy.但是用react去实现就没那么容易了(是自己react比较菜).由于最近在重新学习react ...

  8. 下拉菜单效果和tab选项卡切换

    //下拉菜单效果和tab选项卡切换. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " ...

  9. 原生javascript写自己的运动库(匀速运动篇)

    网上有很多JavaScript的运动库,这里和大家分享一下用原生JavaScript一步一步写一个运动函数的过程,如读者有更好的建议欢迎联系作者帮助优化完善代码.这个运动函数完成后,就可以用这个运动函 ...

随机推荐

  1. 详细介绍android rom移植知识普及

    详细介绍android rom移植知识普及 最近接到很多兄弟们的求助,也回答过无数个和下面这个问题类似的问题: 如何编译android 原生代码得到一个rom,然后跑到某某手机上. 鉴于很多兄弟对这块 ...

  2. android工程gen目录中R.java包名是怎么确定

    新建一个工程,包名用的com.mythroad.adskiller, 后来觉得不好,又改成com.mythroad.adsinscepter,但是我发现gen下的R.java文件的包名还是原来的com ...

  3. C++11 : variadic templates(可变参数模板)

      Introduction: Before the possibilities of the new C++ language standard, C++11, the use of templat ...

  4. USB设备架构

    USB设备,分为3层:1.底层为传送和接受数据的总线接口:2.中间层处理总线和不同端点的数据传输:3.最高层由串行总线设备提供.主要研究中间层. USB设备状态,主要研究外部可见状态. 1,连接态-- ...

  5. 常用元素的属性/方法 attr / val / html /text

    常用元素的属性/方法 得到一个元素的高度, $("#myid").height() 得到一个元素的位置, $("#myid").offset() 返回的是一个o ...

  6. css优先级计算

    主要的css选择器有id,class,tag,[],:,::等,而通常需要对其优先级进行判断的有id,class,tag,另外内联样式和!important也和css的优先级有关系. 如果将这五种不同 ...

  7. (转).NET平台开源JSON库LitJSON的使用方法

    一个简单示例: String str = "{’name’:’cyf’,’id’:10,’items’:[{’itemid’:1001,’itemname’:’hello’},{’itemi ...

  8. Android(工具・集成)

    ■ NDK Android从始(2009)至终是支持JNI的. 只不过一开始没有NDK.需要自己安装交叉编译器创建so,然后放到assert之类捆绑so发布. 有了NDK.有了什么? libc lib ...

  9. PHP实现对MongoDB的基础操作

    PHP扩展                                                                                      PHP5.2.PH ...

  10. 菜鸟做HTML5小游戏 - 刮刮乐

    继上篇翻翻乐之后,又来刮刮乐.还是先上效果图: 开始demo的世界: 1.css去绘制界面效果.(源码提供) 2.原理:要实现刮刮卡内容的出现,我用div做了背景层去显示刮出的内容结果[重点].中间C ...