相关链接:

JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式

JS面向对象(2) -- this的使用,对象之间的赋值,for...in语句,delete使用,成员方法,json对象的使用,prototype的使用,原型继承与原型链

JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法

1、发展史

  面向机器

  面向过程:将程序的执行分解成若干个步骤

  面向对象:将程序的执行分解成若干个事物

2、面向对象两个基本概念

类:代表某类事物,是抽象的

对象:代表某个事物,是具体的

3、快速入门

表达一个人的完整信息

 <script>

     //面向过程
var name = 'zhangsan';
var age = 30;
var marry = true;
alert(name + age + marry); //面向对象
function Person{
}
var p1 = new Person();
p1.name = 'lisi';
p1.age = 20;
p1.marry = true;
alert(p1.name + p1.age + p1.marry); </script>

在面向过程的例子中,我们分别使用了三个变量来定义一个人的完整信息,但这三个变量它们之间没有必然的联系,如:我现在找到变量age,虽然可以取到数据,但并不清楚这是“谁”的年龄。

在面向对象的例子中, function Person{}是构造器。我们可以这样理解,每一个定义的function Person{}都是Person类的构造函数。

4.JS中常见的系统类

1)String类 字符串类

length :取得字符串长度

indexOf(string) :取得参数在字符串中出现的位置

substr(num1,[num2]) :截取字符串

toLowerCase()       :转换为小写

toUpperCase() :转换为大写

replace(str1,str2) :字符串替换

2)Date类   日期类

getYear()        :返回年份(有时会出错,建议用第二种)

getFullYear()  :返回年份

getMonth()     :返回月份 (0---11)

getDate()       :返回每月第几天

getDay()         :返回星期数 (0-6)

getHours()      :返回小时数

getMinutes()   :返回分钟数

getSeconds() :返回秒数

getMilliseconds() :返回毫秒数

3)Math类  数学类

ceil(数值)       :返回大于或等于该数的最小整数(比如说分页 Math.ceil(4.8)=5)

floor(数值)     :返回小于或等于该数的最大整数

min(数值1,数值2) :返回最小数

max(数值1,数值2) :返回最大数

pow(数值1,数值2) :返回数值1的数值2次方

random()              :返回随机数  0----------1

round(数值)   :四舍五入

sqrt(数值)      :开平方根

Math类下的方法都是静态方法

5.自定义类--类的定义

语法:

function 类名(){

}

在js中,没有类的定义语句,只有function,每一个function,我们可以认为它是同名类的构造函数

比如说:

function person(){

}

它是Person类的构造函数

这种函数也叫构造器

6.自定义类--声明对象

语法: var 对象=new 类名();

关键字new:实例化对象, 开辟相应内存空间

 function Person(){
alert('hello');
}
var p1 = new Person();

执行上面这个例子时,我们发现,在实例化时,直接执行了Person构造函数

7.自定义类--关于对象属性的使用

语法:

  对象.属性;

  对象['属性'];

 function Person(){
alert('hello');
}
var p1 = new Person();
p1.name='zhangsan';
p1.age=30;
alert(p1.name+p1.age);

在js中,对象属性是动态添加的,对象属性可以使用“.”或['']这两种形式表示出来

对象的属性可以是任何数据类型,如:字符串、数字、对象

8.三个关键字

constructor: 返回的是对象的构造器

typeof :返回数据类型

instanceof :判断对象是否是某个类的实例

 function Person(){
alert('hello');
}
var p1 = new Person();
p1.name='zhangsan';
p1.age=30;
alert(p1.name+p1.age); //返回p1对象的构造器
alert(p1.constructor);
//取得p1变量的数据类型
alert(typeof p1);
//判断p1是不是Person类的一个实例
alert(p1 instanceof Person);

9.对象在内存中的表现形式

 //例1
function Person(){
}
var p1 = new Person();
p1.name='zhangsan';
p1.age=30; var p2 = new Person();
alert(p2.name);

在例1中,创建p1对象时,会为p1开辟相应的堆空间,然后将name和age属性以及值添加到p1所指向的堆空间中,创建p2对象时,也会为p2对象开辟对应的空间,但p2所指向的堆空间是空的,所以P2对象没有name和age属性。

 //例2
function Person(){
}
var p1 = new Person();
p1.name = 'zhangsan';
p1.age = 30; var p2 = p1;
alert(p2.name);
p2.name = 'lisi';
alert(p2.name);
alert(p1.name);

在例2中,将p1栈中保存的堆的地址赋值给了p2,所以说,p2也指向了p1指向的堆内存的地址。两个对象指向了同一块堆内存,所以改变一个对象的属性,会影响到另一个对象。

 //例3
function Person(){
}
var p1 = new Person();
p1.name = 'zhangsan';
p1.age = 30; var p2 = p1;
alert(p2.name);
p2 = null;
alert(p1.name);
alert(p2.name);

在例3中,P2=null; 表示释放p2所占的栈空间,但p1的空间仍保留,p1仍然指向相应的堆空间,所以删除p2不会影响到p1对象。

JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式的更多相关文章

  1. python面向对象反射-框架原理-动态导入-元类-自定义类-单例模式-项目的生命周期-05

    反射 reflect 反射(reflect)其实是反省,自省的意思 反省:指的是一个对象应该具备可以检测.修改.增加自身属性的能力 反射:通过字符串获取对象或者类的属性,进行操作 设计框架时需要通过反 ...

  2. PHP面向对象(PHP对象在内存中的分配)

    对 像在PHP 里面和整型.浮点型一样,也是一种数据类,都是存储不同类型数据用的, 在运行的时候都要加载到内存中去用,那么对象在内存里面是怎么体现的呢?内存从逻 辑上 说大体上是分为4 段,栈空间段. ...

  3. 剖析c++(三) 类对象在内存中的布局

    基本规则: 1.各data member的自然边界为其字节大小(char为1,short为2,int为4),并按照各自的自然边界对齐: 2.整个object的总自然边界为最大data memeber的 ...

  4. JS获取对象在内存中计算后的样式

    通过obj.style的方式只能取得"内联style"的值,对于<style></style>中的css属性值,则无能为力 . 我们可以用obj.curre ...

  5. JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法

    相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...

  6. JS面向对象(2) -- this的使用,对象之间的赋值,for...in语句,delete使用,成员方法,json对象的使用,prototype的使用,原型继承与原型链

    相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...

  7. js面向对象2

    1.发展史 面向机器 面向过程:将程序的执行分解成若干个步骤 面向对象:将程序的执行分解成若干个事物 2.面向对象两个基本概念 类:代表某类事物,是抽象的 对象:代表某个事物,是具体的 3.快速入门 ...

  8. [js高手之路]从零开始打造一个javascript开源框架gdom与插件开发免费视频教程连载中

    百度网盘下载地址:https://pan.baidu.com/s/1kULNXOF 优酷土豆观看地址:http://v.youku.com/v_show/id_XMzAwNTY2MTE0MA==.ht ...

  9. python笔记-9(subprocess模块、面向对象、socket入门)

    一.subprocess 模块 1.了解os.system()与os.popen的区别及不足 1.1 os.system()可以执行系统指令,将结果直接输出到屏幕,同时可以将指令是否执行成功的状态赋值 ...

随机推荐

  1. python学习 1基础

    对象的等于只是对于值而言 函数定义没有变量提升 常用对象 list []: 列表, 排序省空间 tuple (): 元组,一旦初始化不可修改 dict {}: 字典,方便查询 set {}:集合, 值 ...

  2. Material Design兼容包的使用

    为了方便自己以后的查找,于是就写了这个博客,废话就不多说,开始干: 导入: compile 'com.android.support:appcompat-v7:24.2.1' compile 'com ...

  3. 洛谷 P1466 集合 Subset Sums Label:DP

    题目描述 对于从1到N (1 <= N <= 39) 的连续整数集合,能划分成两个子集合,且保证每个集合的数字和是相等的.举个例子,如果N=3,对于{1,2,3}能划分成两个子集合,每个子 ...

  4. linux 目录权限的特殊之处

    目录的读权限,不能进入目录.仅允许我们读目录,获得在该目录中所有文件名的列表,但无法查看目录中文件的内容. 目录的执行权限,可以进入目录,但不允许我们读取目录的文件列表,但可以查看目录中文件的内容.当 ...

  5. jqueryAjax在客户端发送请求的方式

    get请求方式: $.get函数,发起一个get请求, //第一个参数是请求的url地址, //第二个参数是请求参数,可以是一个urlencode过的字符串,也可以是//一个对象,如果是对象jquer ...

  6. / fluxChatDemo / 系列 ——fluxDemoChat 组件编写

    还是用各部分来表示过程吧,没文采,就先这样记着吧 嘻嘻 梳理问题: 编写es6风格的组件时,需要引入import React from ‘react’ 然后页面就华丽丽的展示出了我写的1.2两个字 在 ...

  7. Sql判断不为Null也不为空的写法

    看到不少人写: isnull(field,'')<>'' 其中这样写最经济实惠:field>''

  8. 【Beta】Daily Scrum Meeting第五次

    1.任务进度 学号 已完成 接下去要做 502 登陆时将返回的个人信息更新到本地数据库 发布任务到服务器 509 给所有api添加注释 添加及修改职工信息并同步到服务器 517 将提交报课移到报课表界 ...

  9. ADO.NET数据访问模板整理

    /// <summary> /// 数据访问类:hi_test /// </summary> public partial class TestDA { public Test ...

  10. Tomcat 配置续

    为了便于tomcat升级 不用频繁重新修改相关配置文件 不用重新部署原有项目 新建目录将tomcat安装目录中的conf,log,webapp,work文件夹复制到里面,然后将系统变量里的CATALI ...