响亮的标题:一个万能的,保底的。面向过程改写成面向对象的方法

前提朗读:很多刚接触js面向对象的时候都不知道如何能快速的写出一个面向对象的程序,这个是必然的现象,不是每一位学js的一上来就会写面向对象的程序。小编这里介绍的方法属于一个面向过程到面向对象的过度期间,(这里要明白面向对象的一些常识:构造函数创建出对象,对象.属性,对象.方法)

一:改写前提步骤:

  1.前提:面向过程中的所有代码都在window.onload 里面
  2.面向过程里面所有的函数都领到外面去(不能有函数嵌套)
  3.提出共同的变量为全局变量(可以有全局变量 当有两个以上的函数都用到了共同的一个变量的话--把这个变量提出来变成全局变量)

小总结4:替换过程(注意this的使用)

面向过程 面向对象
onload(初始化整个程序) 构造函数(初始化对象)
全局变量 属性(对象.属性)     this.属性
函数  方法(构造函数.原型.方法)    构造函数.prototype.方法

** 备注重点:
  改错:this,事件,闭包,传参
  重点:通过闭包传递this

**小编提示:

  面向对象中70%以上都会用到this这个关键字,所以要想使用好面向对象,必须弄明白this

二:案例展示:(不注重要是布局)

1.面向过程案例展示

<script>
window.onload=function ()
{
var oDiv=document.getElementById('div1'); //获取父级
var aBtn=oDiv.getElementsByTagName('input'); //获取oDiv下的所有的input
var aDiv=oDiv.getElementsByTagName('div'); //获取oDiv下的所有div
var i=0; //预先设置变量 i
//思路:清除所有的input元素上的class,并影藏对应的div。
//然后:添加当前点击的那个input的class。并显示对应的那个div for(i=0;i<aBtn.length;i++)
{
aBtn[i].index=i; //给每一个input元素新增加一个属性index
aBtn[i].onclick=function ()
{ //思路:先清除所有的input上面的class,并隐藏input对应的div
for(i=0;i<aBtn.length;i++)
{
aBtn[i].className='';
aDiv[i].style.display='none';
} //思路:然后给当前点击的那个input添加上class = active,并显示出input对应的那个div
this.className='active';
aDiv[this.index].style.display='block';
};
}
};
</script> <div id="div1">
<input class="active" type="button" value="教育" />
<input type="button" value="财经" />
<input type="button" value="aaa" />
<div style="display:block;">11111</div>
<div style="display:none">22222</div>
<div style="display:none">33333</div>
</div>

2.面向过程里面所有的函数都领到外面去(不能有函数嵌套)。提出共同的变量为全局变量

<script>
var aDiv = null; //声明全局变量
var aBtn = null; //声明全局变量 window.onload=function ()
{
var oDiv=document.getElementById('div1'); //获取父级
aBtn=oDiv.getElementsByTagName('input'); //获取oDiv下的所有的input
aDiv=oDiv.getElementsByTagName('div'); //获取oDiv下的所有div
var i=0; //预先设置变量 i
//思路:清除所有的input元素上的class,并影藏对应的div。
//然后:添加当前点击的那个input的class。并显示对应的那个div for(i=0;i<aBtn.length;i++)
{
aBtn[i].index=i; //给每一个input元素新增加一个属性index
aBtn[i].onclick=tab;
}
}; function tab(){
//思路:先清除所有的input上面的class,并隐藏input对应的div
for(i=0;i<aBtn.length;i++)
{
aBtn[i].className='';
aDiv[i].style.display='none';
} //思路:然后给当前点击的那个input添加上class = active,并显示出input对应的那个div
this.className='active';
aDiv[this.index].style.display='block';
};
</script> <div id="div1">
<input class="active" type="button" value="教育" />
<input type="button" value="财经" />
<input type="button" value="aaa" />
<div style="display:block;">11111</div>
<div style="display:none">22222</div>
<div style="display:none">33333</div>
</div>

3,this修改后

<script>
window.onload = function(){
var oTab = new TabSwitch('div1');
} function TabSwitch(id) //构造函数
{
var oDiv=document.getElementById(id); //获取父级
this.aBtn=oDiv.getElementsByTagName('input'); //获取oDiv下的所有的input
this.aDiv=oDiv.getElementsByTagName('div'); //获取oDiv下的所有div
var i=0; //预先设置变量 i
//思路:清除所有的input元素上的class,并影藏对应的div。
//然后:添加当前点击的那个input的class。并显示对应的那个div var _this = this; //this表示new出来的对象 for(i=0;i<this.aBtn.length;i++)
{
this.aBtn[i].index=i; //给每一个input元素新增加一个属性index
this.aBtn[i].onclick=function(){
_this.tab(this); // ** _this表示通过构造函数new出来的对象。 this表示调用事件onclick的对象--> 按钮input
} }
}; TabSwitch.prototype.tab = function(oBtn){
//思路:先清除所有的input上面的class,并隐藏input对应的div
for(i=0;i<this.aBtn.length;i++) //this表示通过构造函数new出来的对象
{
this.aBtn[i].className='';
this.aDiv[i].style.display='none';
} //思路:然后给当前点击的那个input添加上class = active,并显示出input对应的那个div
oBtn.className='active';
this.aDiv[oBtn.index].style.display='block';
};
</script> <div id="div1">
<input class="active" type="button" value="教育" />
<input type="button" value="财经" />
<input type="button" value="aaa" />
<div style="display:block;">11111</div>
<div style="display:none">22222</div>
<div style="display:none">33333</div>
</div>

咱使用this来讲2个面向对象的小案例:this啥时候会出问题。

  1:在定时器里面

  2:在事件里面(通过闭包的方式把this传过去)

面向对象this案例一(正常现象):

<script>
function Aaa(){
this.a = 55;
console.log(this) //表示new出来的对象
} Aaa.prototype.show = function (){
alert(this.a)
console.log(this) //表示new出来的对象
} var obj1 = new Aaa();
obj1.show(); // 55 </script>

面向对象this案例二(定时器里面的this):

<script>
function Aaa(){
this.a = 55;
setInterval(this.show, 3000); //this为 window 证明了定时器里面的this不正常为window
console.log(this) //构造函数对象
}
Aaa.prototype.show = function (){
alert(this) //表示为 window
}
var obj1 = new Aaa();
</script> 改进方法 <script>
function Aaa(){
this.a = 55;
var _this = this ; //this为构造函数的对象,然后赋给一个变量 _this
setInterval(function(){
_this.show(); //_this为 构造函数的对象
}, 3000);
console.log(this) //构造函数对象
} Aaa.prototype.show = function (){
alert(this) //构造函数的对象
}
var obj1 = new Aaa(); </script>

面向对象this案例三(事件里面的this):

<script>
function Aaa(){
this.a = 55;
document.getElementById('odiv1').onclick = this.show;
} Aaa.prototype.show = function(){
alert(this.a); //打印出:undefone 因为:this为 input按钮,但是input按钮上根本没有a这个属性,所以提示为undefine
console.log(this); // this为 input按钮
} window.onload = function(){
new Aaa();
}
</script> 改进后 <script>
function Aaa(){
this.a = 55;
var _this = this; // _this = this = 构造函数的对象 document.getElementById('odiv1').onclick =function(){
_this.show(); //_this 表示为构造函数的对象
}
} Aaa.prototype.show = function(){
alert(this.a); //55
} window.onload = function(){
new Aaa();
}
</script>
<input id="odiv1" type="button" value="按钮">

js面向过程改写成面向对象--通用方法的更多相关文章

  1. MySQL原生API、MySQLi面向过程、MySQLi面向对象、PDO操作MySQL

    [转载]http://www.cnblogs.com/52fhy/p/5352304.html 本文将举详细例子向大家展示PHP是如何使用MySQL原生API.MySQLi面向过程.MySQLi面向对 ...

  2. C++基础——C面向过程与C++面向对象编程01_圆面积求解

    #include "iostream";//包含C++的头文件using namespace std;//使用命名空间std标准的命名空间(在这个命名空间中定义了很多标准定义)vo ...

  3. JS高级 - 面向对象3(面向过程改写面向对象)

    改写: 1.前提:所有东西都在 onload 里 2.改写:不能有函数嵌套,可以有全局变量 onload --> 构造函数 全局变量 --> 属性 函数 --> 方法 4.改错: t ...

  4. js绝对地址图片转换成base64的方法

    //将图片转换成base64 function getBase64Image(url, callback){ var canvas = document.createElement('canvas') ...

  5. js中字符串处理成数字的方法

    <script> var a="11.1111"; var b="12.2222"; //第一种方法:乘以1的方法 //alert(a*1+b*1) ...

  6. js面向过程-拖拽

    1.步骤分析: 1.1 获取id 1.2 当鼠标点击时执行的js 1.3当鼠标移动时执行的js 1.4当鼠标放开时执行的js 2.代码实现 <!DOCTYPE html> <html ...

  7. IDataReader转换成list通用方法

    public static IList<T> ReaderToList<T>(this IDataReader dr) { //DateTime dt = DateTime.N ...

  8. js面向过程-经典选项卡

    源代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8 ...

  9. js 日期证有效性验的通用方法

    开发的理念是“为复用而开发,为使用而组装”,代码的复用度将是项目和产品的一个重要的技术指标. var DateTools={ isDate:function(str) { var result = s ...

随机推荐

  1. LintCode "Swap Two Nodes in Linked List"

    Nothing special. Just take care of corner cases. class Solution { public: /** * @param head a ListNo ...

  2. hyper-v 中 安装 Centos 7.0 设置网络 教程

    安装环境是: 系统:win server 2012 r2 DataCenter hyper-v版本:6.3.9600.16384 centos版本:7.0 从网上下载的 centos 7.0  如果找 ...

  3. Force IE to Open Link in New Tab

    1.First, open Internet Explorer and click on Tools and then Internet Options. 2.Now click on the Set ...

  4. 【sql】之使用sql根据身份证查询过生日人数

    根据当前日期查询有多少人过生日 ,) = DATE_FORMAT(NOW(),'%m'); 查询price一样的人数 select * from people where price in (sele ...

  5. JavaScript中Call()以及Apply()的应用

    apply()和call()的真正用武之地是能够扩充函数赖以运行的作用域 三点说明: 1.每个函数都包含两个非继承而来的方法:apply()和call(). 2.他们的用途相同,都是在特定的作用域中调 ...

  6. (WPF, MVVM) Textbox Binding

    参考:http://msdn.microsoft.com/en-us/library/system.windows.data.updatesourcetrigger(v=vs.110).aspx Te ...

  7. API 双方认证探讨

    开放 api 已是大势所趋.而 api 这种东西有个特点就是覆水难收.一旦公开出去了,被大量用户使用,一旦修改,就会让广大用户都掉坑里.所以,api 在设计之初就要尽量考虑周全,并预留扩展可能. 目前 ...

  8. jQuery实现的鼠标滑过切换图片代码实例

    jQuery实现的鼠标滑过切换图片代码实例:有时候网页需要这样的简单效果,那就是当鼠标滑过默认图片的时候,能够实现图片的切换,可能在实际应用中,往往没有这么简单,不过大家可以自行扩展一下,下面简单介绍 ...

  9. VVDocumenter-Xcode 规范注释生成器 插件之安装调试适应新版本

    1.下载地址: 很多时候,为了快速开发,很多的技术文档都是能省则省,这个时候注释就变得异常重要,再配合Doxygen这种注释自动生成文档的,就完美了.但是每次都要手动输入规范化的注释,着实也麻烦,但有 ...

  10. 程序员遇到Bug时的30个反应

    开发应用程序是一个非常有压力的工作.没有人是完美的,因此在这个行业中,代码中出现bug是相当普遍的现象.面对bug,一些程序员会生气,会沮丧,会心烦意乱,甚至会灰心丧气,而另一些程序员会依然保持冷静沉 ...