js面向对象2
1、发展史
面向机器
面向过程:将程序的执行分解成若干个步骤
面向对象:将程序的执行分解成若干个事物
2、面向对象两个基本概念
类:代表某类事物,是抽象的
对象:代表某个事物,是具体的
3、快速入门
表达一个人的完整信息
1 <script>
2
3 //面向过程
4 var name = 'zhangsan';
5 var age = 30;
6 var marry = true;
7 alert(name + age + marry);
8
9 //面向对象
10 function Person{
11 }
12 var p1 = new Person();
13 p1.name = 'lisi';
14 p1.age = 20;
15 p1.marry = true;
16 alert(p1.name + p1.age + p1.marry);
17
18 </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:实例化对象, 开辟相应内存空间
1 function Person(){
2 alert('hello');
3 }
4 var p1 = new Person();
执行上面这个例子时,我们发现,在实例化时,直接执行了Person构造函数
7.自定义类--关于对象属性的使用
语法:
对象.属性;
对象['属性'];
1 function Person(){
2 alert('hello');
3 }
4 var p1 = new Person();
5 p1.name='zhangsan';
6 p1.age=30;
7 alert(p1.name+p1.age);
在js中,对象属性是动态添加的,对象属性可以使用“.”或['']这两种形式表示出来
对象的属性可以是任何数据类型,如:字符串、数字、对象
8.三个关键字
constructor: 返回的是对象的构造器
typeof :返回数据类型
instanceof :判断对象是否是某个类的实例
1 function Person(){
2 alert('hello');
3 }
4 var p1 = new Person();
5 p1.name='zhangsan';
6 p1.age=30;
7 alert(p1.name+p1.age);
8
9 //返回p1对象的构造器
10 alert(p1.constructor);
11 //取得p1变量的数据类型
12 alert(typeof p1);
13 //判断p1是不是Person类的一个实例
14 alert(p1 instanceof Person);
9.对象在内存中的表现形式
1 //例1
2 function Person(){
3 }
4 var p1 = new Person();
5 p1.name='zhangsan';
6 p1.age=30;
7
8 var p2 = new Person();
9 alert(p2.name);
在例1中,创建p1对象时,会为p1开辟相应的堆空间,然后将name和age属性以及值添加到p1所指向的堆空间中,创建p2对象时,也会为p2对象开辟对应的空间,但p2所指向的堆空间是空的,所以P2对象没有name和age属性。
1 //例2
2 function Person(){
3 }
4 var p1 = new Person();
5 p1.name = 'zhangsan';
6 p1.age = 30;
7
8 var p2 = p1;
9 alert(p2.name);
10 p2.name = 'lisi';
11 alert(p2.name);
12 alert(p1.name);
在例2中,将p1栈中保存的堆的地址赋值给了p2,所以说,p2也指向了p1指向的堆内存的地址。两个对象指向了同一块堆内存,所以改变一个对象的属性,会影响到另一个对象。
1 //例3
2 function Person(){
3 }
4 var p1 = new Person();
5 p1.name = 'zhangsan';
6 p1.age = 30;
7
8 var p2 = p1;
9 alert(p2.name);
10 p2 = null;
11 alert(p1.name);
12 alert(p2.name);
在例3中,P2=null; 表示释放p2所占的栈空间,但p1的空间仍保留,p1仍然指向相应的堆空间,所以删除p2不会影响到p1对象。
js面向对象2的更多相关文章
- js面向对象学习 - 对象概念及创建对象
原文地址:js面向对象学习笔记 一.对象概念 对象是什么?对象是“无序属性的集合,其属性可以包括基本值,对象或者函数”.也就是一组名值对的无序集合. 对象的特性(不可直接访问),也就是属性包含两种,数 ...
- 带你一分钟理解闭包--js面向对象编程
上一篇<简单粗暴地理解js原型链--js面向对象编程>没想到能攒到这么多赞,实属意外.分享是个好事情,尤其是分享自己的学习感悟.所以网上关于原型链.闭包.作用域等文章多如牛毛,很多文章写得 ...
- JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法
相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...
- JS面向对象(2) -- this的使用,对象之间的赋值,for...in语句,delete使用,成员方法,json对象的使用,prototype的使用,原型继承与原型链
相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...
- JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式
相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...
- js面向对象的实现(example 二)
//这个方法和上篇文章(js面向对象的实现(example 一))中的方法类似,但是更为简洁 //通过函数赋值的方式来构造对象 //同样通过闭包的方式来封装对象及内部变量 (function () { ...
- 浅谈JS面向对象之创建对象
hello,everybody,今天要探讨的问题是JS面向对象,其实面向对象呢呢,一般是在大型项目上会采用,不过了解它对我们理解JS语言有很大的意义. 首先什么是面向对象编程(oop),就是用对象的思 ...
- js面向对象,有利于复用
需求:在网页上添加个天气预报. 以前总是在需要执行js的地方,直接写function(){}.在需要同样功能的地方直接copy,或者稍微修改. 然后在网上看看有没有好点的方法,然后就看到js面向对象编 ...
- JavaScript基础精华02(函数声明,arguments对象,匿名函数,JS面向对象基础)
函数声明 JavaScript中声明函数的方式:(无需声明返回值类型) function add(i1, i2) { return i1 + i2;//如果不写return返回 ...
- 原生JS面向对象思想封装轮播图组件
原生JS面向对象思想封装轮播图组件 在前端页面开发过程中,页面中的轮播图特效很常见,因此我就想封装一个自己的原生JS的轮播图组件.有了这个需求就开始着手准备了,代码当然是以简洁为目标,轮播图的各个功能 ...
随机推荐
- VM12安装Mac系统操作指南
1.第一步,操作按照这个链接来搞 VMware 12安装Mac OS 系统使用的是 OS X 10.11.1(15B42) 2.激活工具一定要使用 unlocker208 3.初次安装可能存在的报错 ...
- Linux环境下jdk、tomcat、redis安装及配置
环境说明: linux : centOS jdk : 1.8 tomcat : 8.5 redis : 4.0 jdk安装配置 1.下载jdk(这里下载的是jdk-8u181-linux-x64.ta ...
- oracle重新编译所有invalid objects
点第一个,按住shift键点最后一个,右键recompile就OK了
- 题解 P1436 【棋盘分割】
题目链接 其实呢大致思路和下面的大佬们都很像.发这篇题解的目的就是加了一点~~优化~~骗分技巧. 转移方程: 设$dp[i][j][x][y][k]$表示左上$(i,j)$,右下$(x,y)$,第$k ...
- 解决 Github用户名 变为 invalid-email-address 问题
解决 Github用户名 变为 invalid-email-address 问题 If the identity used for this commit is wrong, you can fix ...
- 《条目十八》避免使用vector<bool>
<条目十八>避免使用vector 先说结论: 一是:vector<bool>不是标准容器,因为标准容器的对于T *p = &c[0];必须是可编译的. 二是:vecto ...
- phpstorm利用database连接mysql数据库
首先声明一点,database只能连接一个已存在的数据库,不能创建数据库 连接一个已存在的数据库步骤: 1,找到database:连续点击俩次shift,输入database就能找到了 2,点击绿色的 ...
- screen虚拟终端
screen命令相当于后台执行(虚拟终端) 用法:在一些要执行很久的操作,比如我有个文件有10个G,要传输一天左右,你如果是直接传输,万一你的连接断了.是不是意味着你的操作白费的呢,这时我们可以打开一 ...
- uiautomator中文输入
步骤一: 下载UTF7 IME的整个项目 https://github.com/sumio/uiautomator-unicode-input-helper 选择“Download ZIP”打包下载 ...
- Spring Eureka的使用入门--服务端与客户端
接上篇: Eureka作为注册中心,连接服务端与客户端: 服务端: 依赖包: apply plugin: 'org.springframework.boot' apply plugin: 'io.sp ...