面向对象系列讲解—认识对象

HTML5学堂:面向对象、原型、继承应该说是属于JavaScript最底层的知识和概念,对于这些知识,在我们没有触碰的时候的确觉得是比较困难的,包括在学习的过程中,也觉得摸不到头脑,但是当走过之后,发现也没有那么难。面向对象,从认识对象开始。为了方便大家学习和查看,所以特意控制了文章的篇幅,将面向对象写成了多篇连续博文的方式,也方便大家根据自己具体情况进行选择性的学习。

在自己最初学习面向对象的时候,一直陷入了一个误区。当时自己知道this和面向对象相关,也知道原型prototype和面向对象相关,于是,在最初进行面向对象代码书写的时候,直接就使用this开始书写,但是逻辑上却是错乱的。同时,面向对象这个东西通常是用于一些模块化开发当中,在接触到一个比较通用模块之前,自己并不清楚面向对象在JS中的用法。

随着时间的推移,和对面向对象的理解的逐步深入,自己也就慢慢捋顺了面向对象的代码开发的实际顺序和逻辑。在此书写出来,希望各位不要像我一样绕弯路。

对象命名空间

在讲解面向对象之前,先来讲解一下对象命名空间。我们常说,常见避免js命名冲突的方法有三种,分别是匿名函数、协同命名以及对象命名空间。那么这个对象命名空间到底是个什么玩意儿呢?来看下面这段代码:

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>面向对象-独行冰海</title>
</head>
<body>
<script>
var username = '独行冰海';
</script>
</body>
</html>

全局作用域

我们在全局作用域定义了一个变量,变量名为username。在之前的博文中我们曾经介绍过,在全局作用域指的是window。那么在全局作用域定义的变量或者函数都可以看做是window的属性(变量)或方法(函数),那么此时window其实就是username这个属性的对象。也就是说:username 等价于 window.username;来看下面这段代码:

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>面向对象-独行冰海</title>
</head>
<body>
<script>
var username = '独行冰海';
window.username = '独行冰海'; // 与上面一行等价
alert(username);
</script>
</body>
</html>

防止全局作用域被污染

接下来我们以一个小例子为例,看看如何用对象命名空间的方式进行代码的书写,同时也再理解一下所谓的“防止全局作用域被污染”。首先采用普通创建的方法,实现一个用户名、博客地址、微博地址等基本信息的创建,同时创建一个函数,功能是将这个人的基本信息展示出来,书写方法如下:

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>面向对象-独行冰海</title>
</head>
<body>
<script>
var username = '独行冰海';
var blogsrc = 'http://blog.163.com/hongshaoguoguo@126';
var weibo = 'http://weibo.com/u/2706684357';
function showInf(){
alert('姓名:'+username+'\n博客地址:'+blogsrc+'\n微博地址:'+weibo);
}
showInf();
</script>
</body>
</html>

当前相当于在全局作用域下创建了3个变量,1个函数,它们四个都属于window对象,接下来我们来思考一下,如果我们的工作伙伴在书写js代码的时候,也使用了username或者showing此类的变量名或函数名,再将我们的代码进行整合,之后会出现什么问题?——必然会发生变量或函数的覆盖,从而导致代码出现问题。那么对象命名空间就是解决这个冲突的好办法。我们使用一个对象进行这一系列属性和方法的存储,让它们都属于某一个对象,来看代码:

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>面向对象-独行冰海</title>
</head>
<body>
<script>
var obj = {};
obj.username = '独行冰海';
obj.blogsrc = 'http://blog.163.com/hongshaoguoguo@126';
obj.weibo = 'http://weibo.com/u/2706684357';
obj.showInf = function (){
alert('姓名:'+obj.username+'\n博客地址:'+obj.blogsrc+'\n微博地址:'+obj.weibo);
}
obj.showInf();
</script>
</body>
</html>

此时,只有obj这个变量属于window,而username、blogsrc、weibo、showing都属于obj,那么此时如果我们的工作小伙伴们也需要使用到username等属性或方法,那么他只需再创建一个属于他自己的对象,再将这些属性和方法放置于对象之下,即obj2.username等。

从上面的效果不难看出,如此操作之后,附属于window这个对象下的属性和方法的数量大大的减少了,那也就不难理解所谓的“尽可能的防止全局作用域被污染,减少命名冲突”这句话了。

原文发布于微信公众号 - HTML5学堂(h5course-com)

原文发表时间:2016-02-17

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏大数据钻研

HTML5新增及移除的元素

HTML经过10多年的发展,其元素经历了废弃与不断重新定义的过程。为了更好的处理现在的互联网应用,HTML5新增了图形绘制、多媒体播放、页面结构、应用程序存储、...

2538
来自专栏抠抠空间

jQuery基础

一、jQuery是什么? jQuery是一个轻量级的、兼容多浏览器的JavaScript库。 jQuery使用户能够更方便地处理HTML Documen...

28012
来自专栏web前端教室

大白话 Promise,这到底是干啥用的?

任何东西不可能凭空出来。那么Promise,它到底是个啥?干嘛用的?为解决什么问题而出现的?咱们以这几个问题为线索,简单的说一下。为什么说是简单说一下呢?因为要...

1889
来自专栏知道一点点

Angularjs快速入门(二)

说说上一节的例子,$scope 我们没有创建这个对象,直接绑定就能获取里面的对象,这种风格遵循了一种叫迪米特法则的设计模式。

881
来自专栏软件开发

CSS3与页面布局学习总结(一)——概要、选择器、特殊性与刻度单位

web前端开发者最最注的内容是三个:HTML、CSS与JavaScript,他们分别在不同方面发挥自己的作用,HTML实现页面结构,CSS完成页面的表现与风格,...

1898
来自专栏老马寒门IT

03-Vue入门系列之Vue列表渲染及条件渲染实战

3.1. 条件渲染 有时候我们要根据数据的情况,决定标签是否进行显示或者有其他动作。最常见的就是,表格渲染的时候,如果表格没有数据,就显示无数据。如果有数据就显...

2158
来自专栏新工科课程建设探讨——以能源与动力工程专业为例

2.2.2 HTML标签简介

HTML(HyperText Mark-up Language)是由HTML标签嵌套和组合的描述性文本,HTML标签可以描述文本(p,div等)、表格(tabl...

690
来自专栏coding for love

CSS常用布局实现05-圣杯布局和双飞翼布局

其实对于三列布局的实现,之前网上使用最多的还是这两种。它们有一个共同的优点,就是可以使主内容优先加载。当然,如果不考虑兼容,flex和grid还是优先推荐的。

522
来自专栏Jerry的SAP技术分享

使用JavaScript给对象修改注册监听器

我们在开发一些大型前端项目时,会遇到这样一种情况,某个变量上有个字段。我们想知道是哪一段程序修改了这个变量上的字段。比如全局变量window上我们自定义了一个新...

552
来自专栏柠檬先生

vue2.0 配置 选项 属性 方法 事件 ——速查

全局配置               silent        设置日志与警告     optionMergeStrategies         合并策...

1769

扫码关注云+社区