js面向对象(一)——封装
想写这个好久了,自己当时理解这个确实费了一番功夫,现在记录一下,哪怕对读者有一点点帮助,我也很开心,看着不爽大胆喷吧,我脸皮可厚了,闲话不说了,进入正题
--------------------------------------------------我是分割线---------------------------------------------------------
JavaScript是一门基于对象的语言,但它又不是传统意义上的面向对象程序编程语言,它不像java语言有类(class)的概念(es6不算,否则就打脸了),
首先什么是对象?简单说什么都是对象,对象具有封装和继承,以及对象与对象之间使用消息通讯,各自之间消息隐藏
对象的特性为封装、继承和多态;
本节我们就说说封装:
举个例子:
var dog1={};
dog1.name="道哥";
dog1.six="公";
alert(dog1.name) //输出道哥
var dog2={};
dog2.name="二哈";
dog2.six="公";
alert(dog2.name) //输出二哈
这就是一个简单的面向对象的封装,不过这中方式很low(不然怎么能说后面的方法高明呢),当对象很多,这样建立对象不仅费时费力而且会浪费大量内存,不可取,所以我改进了一下,引入函数
function Dog(name,s){
this.name=name;
this.sex=s;
this.type="犬科";
this.speck=function(){
alert("汪汪。。。")
}
}
var dog1=new Dog("道哥","公");
var dog2=new Dog("二哈","公");
alert(dog1.name): //输出道哥
alert(dog2.name): //输出二哈
alert(dog1.type); //输出犬科
alert(dog2.type); //输出犬科
这样就高明了不少,当然也有不足,就像你在一家狗舍,里面有很多狗,然后你问这狗叫啥,饲养员说是“道哥”,然后你问它是什么类型,饲养员说是“犬科”,狗很多,你这样问估计饲养员早就烦了,那假如我们在狗舍的墙上写一张告示,上面写明所有狗的共同特性,比如类型,叫声等等嗯,那些共同属性有人问往墙上一指就看到了;
放在代码里就是每建立一个对象就需要重新建立那些共有的属性,这样会浪费大量的内存,很不明智,那么代码中有没有像上面的那么一块“告示牌”呢?答案是当然有。这里我们就需要引入一个新的名词:“prototype”,这是函数的一个属性(每个函数都有一个prototype属性),这个属性是一个指针,指向一个对象,我们可以将我们要定义的方法添加给prototype属性,即
function Dog(name,s){
this.name=name;
this.sex=s;
}
Dog.prototype.type="犬科";
Dog.prototype.spack=function(){
alert("汪汪。。。")
};
var dog1=new Dog("道哥","公");
var dog2=new Dog("二哈","公");
此刻我们可以输出
alert(dog1.name) //输出道哥
alert(dog1.type) //输出犬科
dog1.spack(); //弹出汪汪。。。
alert(dog2.name) //输出二哈
alert(dog2.type) //输出犬科
dog2.spack(); //弹出汪汪。。。
因为prototype是一个指针,所以此刻所有的实例(name和spack()),其实都是同一内存地址,指向了prototype对象
下面列一些检测protopypt的方法:
//isPrototypeOf是检测protopype对象和实例之间的关系,如下面输出,dog1继承于Dog,故输出为true,而cat1继承于Cat,与Dog没啥关系,所以输出为false
alert(Dog.prototype.isPrototypeOf(dog1)); //true
alert(Dog.prototype.isPrototypeOf(cat1)); //false //hasOwnProperty属性判断该属性是自己的属性还是继承于prototype的属性,name是dog1自己的属性,所以输出为1,而type是继承于prototype的属性,所以输出为false
alert(dog1.hasOwnProperty("name")); //true
alert(dog1.hasOwnProperty("type")); //false //in是检测该属性是否是对象的属性,不管是自己的属性还是继承于prototype的属性,例如下面的name和spack是cat1的属性,所以输出为true,而cat1并没有“wife”的属性,所以输出为false;当然in也可以遍历对象的所有属性;
alert("name" in cat1);
alert("spack" in cat1);
alert("wife" in cat1); //in遍历属性
for(var i in dog1){
alert("dog1---"+i) //这样就能输出所有的属性了
}
--------------------------------------------------------------------------------------------------------------------------------------------------------------------
本文借鉴阮大师文章,地址如下:
http://www.ruanyifeng.com/blog/2010/05/object-oriented_javascript_encapsulation.html
js面向对象(一)——封装的更多相关文章
- 原生JS面向对象思想封装轮播图组件
原生JS面向对象思想封装轮播图组件 在前端页面开发过程中,页面中的轮播图特效很常见,因此我就想封装一个自己的原生JS的轮播图组件.有了这个需求就开始着手准备了,代码当然是以简洁为目标,轮播图的各个功能 ...
- JS面向对象(封装,继承)
在六月份找工作中,被问的最多的问题就是: js面向对象,继承,封装,原型链这些,你了解多少? 额,,,我怎么回答呢, 只能说,了解一些,不多不少,哈哈哈哈,当然,这是玩笑话. 不过之前学过java,来 ...
- 用js面向对象思想封装插件
js是基于原型的面向对象语言,如果你学过java,c#等正统面向对象语言,你会难以理解js的面向对象,他和普通的面向对象不太一样,今天,我们通过封装一个toast插件,来看看js面向对象是如何运行的. ...
- Js 面向对象之封装,继承,原型,原型链
封装 ,继承 ,原型, 原型链 封装 ? 面向对象有三大特性,封装.继承和多态.对于ES5来说,没有class(类)的概念,并且由于JS的函数级作用域(函数内部的变量在函数外访问不到),所以我们就可以 ...
- 实例了解js面向对象的封装和继承等特点
1.面向对象特点 相比之前按照过程式写法,面向对象有以下几个特点; 1.抽象:抓住核心问题,就是将很多个方法放在一个对象上.对象由属性和方法组成,属性就是我们定义的变量,它是静态的:方法就是行为操作, ...
- 个人对js面向对象和封装插件的用法
做了一段时间的前端了,给自己写代码也总结出来了一点小小的思路,就来分享一下自己的意见和建议了. 面向对象和插件封装其实说到底都是面向对象的思想,但是插件一般是你要用的时候就new 调用出来的.就说一下 ...
- js面向对象的封装方法,【案例】
封装方法: /** * @矩形canvas库 * @authors Shimily (275766400@qq.com) * @date 2016-12-28 10:30:51 * @version ...
- 拖拽系列二、利用JS面向对象OOP思想实现拖拽封装
接着上一篇拖拽系列一.JavaScript实现简单的拖拽效果这一篇博客将接着对上一节实现代码利用JS面向对象(OOP)思维对上一节代码进行封装; 使其模块化.避免全局函数污染.方便后期维护和调用:写到 ...
- canvas+js+面向对象的圆形封装
效果: Circle.js /* 1. 封装属性: x, y r, fillStyle strokeStyle opacity 2.render */ function Circle(option) ...
- canvas+js+面向对象的矩形封装
效果: Rect.js /* 1. 封装属性: x, y w , h, fillStyle strokeStyle rotation opacity 2.render */ function Rect ...
随机推荐
- jenkins持续集成之Global Tool Configuration的配置
Global Tool Configuration的配置过程: 1.点击系统管理2.点击 Global Tool Configuration3.必须配置: jdk git ant maven 1.点击 ...
- javaScript总结51: 变量查找规则与词法作用域
作用域: 1 在es5.0中只有函数可以构成一个作用域 2 全局作用域: 整个js代码执行的环境 3 局部作用域: 函数可以构成一个局部作用域 4 全局变量: 在全局作用域中申明的变量 5 局部变量: ...
- OpenNIDataGet 获取点云数据
运行后,采集的数据保存到:E:\OpenCVData目录下的color和depth文件夹下.接下来要求参数:内参 外参 这些参数最好优化后使用精度高 如何得到+保存格式 yaml 保存文件格式: 1. ...
- unity 小地图的制作
利用 Transform.InverseTransformDirection 变换位置从世界坐标到自身坐标. 以第一人称控制器为坐标原点(忽视y轴),x轴z轴转为屏幕坐标. 若物体在地图范围外,可以 ...
- docker中安装Jenkins
1.获取Jenkins镜像(不要直接docker pull jenkin,这样获取的不是最新的版本,后续安装部分插件会不成功) docker pull jenkins/jenkins 创建文件夹 su ...
- 前台通过form表单向Django后台传输数据,Django处理后返回给前台
摘要:Django前后台数据传递 通过action将数据传输给apitest这个地址,使用get方法传递,此处需要传递name="request_method"的下拉列表值和nam ...
- Crystal Reports for Visual Studio 2015 安装
如果你在vs2015下要用到Cystal Reports,请安装下面的插件.安装时请退出vs2015,安装后重启. https://www.aspsnippets.com/Articles/Downl ...
- 菜鸟的Xamarin.Forms前行之路——实现按钮的字体图标(可扩展)
在实际的APP中,带有图标的按钮用到地方还是蛮多的,字体图标往往能更快更生动的传达信息,并且相对于背景图片,字体图标也有着绝对的优势,所以实现按钮的字体图标是值得尝试的. 实现方法:各平台自定义渲染按 ...
- ZKEACMS for .Net Core 深度解析
ZKEACMS 简介 ZKEACMS.Core 是基于 .Net Core MVC 开发的开源CMS.ZKEACMS可以让用户自由规划页面布局,使用可视化编辑设计“所见即所得”,直接在页面上进行拖放添 ...
- Centos7 中使用搭建devpi并且使用Supervisor守护进程
一.先介绍一下supervisor 1.安装supervisor 使用yum安装或者使用pip安装都可以,使用yum安装的相对简单一些,并且不用拷贝一份 supervisord.conf 的配置文件, ...