js面向对象(一)---基本的概念、属性、方法
一、什么是面向对象编程
1、用对象的思想去写代码,就是面向对象编程
2、我们一直在使用对象,如数组Array 时间Date
//我们把系统自带的对象,叫做系统对象
var arr = new Array();
arr.length;
arr.push();
二、面向对象编程(oop)的特点
抽象:抓住核心问题
封装:只能通过对象来访问方法
继承:从已有对象上继承出新的对象
多态:多对象的不同形态
三、高级面向对象的一些概念、名词
1、包装对象:JS基于原型的程序,包括String、Number、Boolean
//这个基本类型的包装对象类型是String
var str = "hello";
//基本类型会找到对应的包装对象类型,然后包装对象把所有的属性和方法给了基本类型,然后包装对象消失
str.charAt(0); //h
2、原型链:
-实例对象与原型之间的连接,叫做原型链
-_proto_(隐式链接)
-Object对象类型是原型链的最外层
function Aaa(){
this.num = 20;
}
Aaa.prototype.num = 10;
Object.prototype.num = 30;
var a1 = new Aaa();
alert(a1.num); //20
/*对象是可以找到原型下的东西的,num是挂载到构造函数Aaa()的原型上,而构造函数的原型本身就是个对象,
num其实就是Aaa.prototype这个对象下面的属性。 而a1之所以能找到num,是因为a1与Aaa()之间有一个链接,
这个链接就称为原型链。 a1本身是没有num的,所以a1先往自己身上找,没找到然后才顺着原型链一层一层的往上找
*/
//原型链的最外层:object:prototype
四、面向对象的一些属性和方法(虽然用得比较少)
hasOwnProperty():看是不是对象自身下面的属性
var arr = [];
arr.num = 10;
Array.prototype.num2 = 20; alert(arr.hasOwnProperty('num')) //true
alert(arr.hasOwnProperty('num2')) //false
constructor : 查看对象的构造函数。----每个原型都会自动添加constructor属性,for in 的时候有些属性是找不到的,要避免修改constructor属性
function Aaa(){}
//创建构造函数后,系统1自动创建的这个属性
Aaa.prototype.constructor = Aaa;
//在给原型这样添加变量时,记得修正construcor的指向,
Aaa.prototype = {
construcor: Aaa,
name : '小明',
age : 20
}
var a1 = new Aaa();
alert(a1.constructor); //function Aaa(){}
instanceof : 运算符。---对象与构造函数在原型链上是否有关系
function Aaa(){}
var a1 = new Aaa();
alert(a1 instanceof Aaa); //true
alert(a1 instanceof Object); //true
alert(a1 instanceof Array); //false
toString() : object上的方法,把对象转成字符串
//变成字符串
var arr = [1,2,3];
alert(arr.toString()); //'1,2,3' //数字进制转换 这里是16进制
var num = 225;
alert(num.toString(16)); //'e1' //利用toStriing作类型的判断 ,这是判断类型最完美的方法
var arr = null;
var arr2 = [];
alert(Object.prototype.toString.call(arr) == '[object Array]') //false
alert(Object.prototype.toString.call(arr2) == '[object Array]') //true
js面向对象(一)---基本的概念、属性、方法的更多相关文章
- Python面向对象静态方法,类方法,属性方法
Python面向对象静态方法,类方法,属性方法 属性: 公有属性 (属于类,每个类一份) 普通属性 (属于对象,每个对象一份) 私有属性 (属于对象,跟普通属性相似,只是不能通过对象直接访问) 方法: ...
- js如何操作表格(常用属性方法汇总)
js如何操作表格(常用属性方法汇总) 一.总结 一句话总结: 二.表格相关的属性和方法 1.1 Table 对象集合 cells[] 返回包含表格中所有单元格的一个数组. 语法:tableObject ...
- JS面向对象编程,对象,属性,方法。
document.write('<script type="text/javascript" src="http://api.map.baidu.com/api?v ...
- python 面向对象静态方法、类方法、属性方法、类的特殊成员方法
静态方法:只是名义上归类管理,实际上在静态方法里访问不了类或实例中的任何属性. 在类中方法定义前添加@staticmethod,该方法就与类中的其他(属性,方法)没有关系,不能通过实例化类调用方法使用 ...
- JS面向对象之工厂模式
js面向对象 什么是对象 "无序属性的集合,其属性可以包括基本值.对象或者函数",对象是一组没有特定顺序的的值.对象的没个属性或方法都有一个俄名字,每个名字都映射到一个值. 简单来 ...
- js面向对象编程 ---- 系列教程
原 js面向对象编程:数据的缓存 原 js面向对象编程:如何检测对象类型 原 js面向对象编程:if中可以使用那些作为判断条件呢? 原 js面向对象编程:this到底代表什么?第二篇 原 js面向对象 ...
- JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法
相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...
- js面向对象之公有、私有、静态属性和方法详解
现下,javascript大行其道,对于网站开发人员来说,javascript是必需掌据的一门语言,但随着jquery等框架的流行和使用,许多人对于原生javascript缺乏深入的理解,习惯了函数式 ...
- js面向对象自定义MyString()的构造器函数,实现内建String()属性和方法:
js面向对象自定义MyString()的构造器函数,实现内建String()属性和方法: var s = new MyString('hello'); s.length; s[0]; // " ...
- js面向对象学习 - 对象概念及创建对象
原文地址:js面向对象学习笔记 一.对象概念 对象是什么?对象是“无序属性的集合,其属性可以包括基本值,对象或者函数”.也就是一组名值对的无序集合. 对象的特性(不可直接访问),也就是属性包含两种,数 ...
随机推荐
- python作业/练习/实战:下载QQ群所有人的头像
步骤与提示:1.在腾讯群网页中进入任意一个群,获取相关信息,可以用postman是试一下,可以看到我们要的是mems里面的数据,需要获取到QQ号和群名片,如果没有群名片的话取昵称2.根据QQ号下载头像 ...
- 【React】react&&redux调试工具
一.React调试工具 1.安装 react-developer-tools,在chrome应用商店进行下载,因为网络限制原因,我们可以使用火狐浏览器进行安装下载 a.打开火狐浏览器的附加组件 b.搜 ...
- nodeType介绍及应用示例
一,DOM中的节点类型介绍 DOM将一份文档抽象为一棵树,而树又由众多不同类型的节点构成. 元素节点是DOM中的最小单位节点,它包括了各种标签,比如表示段落的p,表示无序列表的ul等. 文本节点总是被 ...
- maven命名
<dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpcl ...
- HDU 1261 字串数(排列组合)
字串数 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...
- 学习JS基本数据类型与对象的valueOf方法
https://blog.csdn.net/licheng11403080324/article/details/60128090 https://yq.aliyun.com/articles/399 ...
- MES training
unique identity 1.project name , namespace 2. select XML (not html) 3. view and controller will be i ...
- [转]【Git】rebase 用法小结
https://www.jianshu.com/p/4a8f4af4e803 本文主要参考 https://git-scm.com/docs/git-rebase rebase在git中是一个非常有魅 ...
- 【Jquery对象】jquery与dom对象的区别
最近工作有很多判断的代码,用到了jquery与dom对象的地方比较多,写在这里加强下基本概念: 1.判断是否存在时候,要用dom对象,因为jQuery在获得对象的时候,无论要获得的对象是否存在,都会返 ...
- 【TJOI2018】教科书般的亵渎
题面 题目描述 小豆喜欢玩游戏,现在他在玩一个游戏遇到这样的场面,每个怪的血量为\(a_i\),且每个怪物血量均不相同,小豆手里有无限张"亵渎".亵渎的效果是对所有的怪造成11点伤 ...