JS面向对象特性和值类型与复合类型
JS面向对象之特性已经值类型与复合类型
一些属性
- 空对象
- 空对象也是对象, 只是有存变量的变量名, 没有对象属性
var o ={};
- 参数传递
- 值类型: 函数内外两个变量, 两个数据, 都不相同
- 引用类型: 函数内外变量不同, 一个数据, 相同地址
赋值
var num =123;var num2 = num;
值类型的赋值特点
- 将变量内的数据全部拷贝一份, 赋值的变量
var num = 123表示变量中存储中的数字是 123- 将 123 数据拷贝一份, 内存中有 2 个数据
- 将拷贝数据复制给
num2 - 特点是在内存中有2个数据副本
引用(复合)类型赋值
var o ={ name :'张三'};var obj = o;
- 引用类型赋值就是将变量 o 中存储的数据拷贝一份( 地址 ), 然后将数据赋值给obj
- 内存中只有1份数据
- 特点是两个变量,一个数据,指向同一个地址
深拷贝与浅拷贝( 保证对象的属性也是引用类型 )
深拷贝的概念
- 拷贝的时候, 将数据中的所有引用类型的值, 全部拷贝一份, 数据在内存中独立, 就是深拷贝
- 修改拷贝数据和源数据, 没有联系
- 特点: 内存隔离,完全独立
浅拷贝的概念
- 拷贝的时候, 只针对当前对象的属性进行拷贝, 而引用类型不考虑
对象的动态特性
在 js 中, 一个对象需要属性, 就可以利用
对象.属性名 = 值的方式, 为这个对象添加成员, 只要赋值成功, 对象就增加了新的属性- 想要添加方法, 就添加方法
- 想要添加属性, 就添加属性
- 想要移除属性或方法, 使用
delete
对象属性的访问形式
- 点语法:
o.name - 关联数组:
o[name]
- 点语法:
混入方法( extend )
function extend(o1, o2){for(var key in o2){o1[key]= o2[key];}}
- 如果需要给对象动态添加成员, 必须使用关联数组语法
var o ={name :'张三',sayHello :function(){console.log('Hello, 我叫'+this.name );}}console.log( o.name );// 访问的是 o 的name 属性console.log( o['name']);o.sayHello();o['sayHello'];// []中的是字符串
参数传递
- 作为函数中的参数, 就是将参数的数据复制一份, 传递给函数的形参
function foo(num){}var a =123;foo(a);
* 函数在调用的时候, 首先需要将参数中的数据复制一份, 数字 123 复制一份
* 跳转到函数中, 完成形参赋值, num = 123;
* 进入函数体, 执行每一句函数
- 值类型作为函数参数传递的特征, 函数内与函数外是两个不同的变量, 只是值相等
- 引用类型作为函数参数传递的特征, 函数内与函数外是两个不同的变量, 但是是指向相同得自, 指向同一个对象
- 函数内部允许修改函数外部的对象的数据
构造函数
构造函数的作用
- new 的作用, 初始化数据
- 在 js 给对象添加属性时, 使用对象的动态特性结合this(这里this指的是使用构造函数创建的实例对象), 来进行赋值, 添加成员
构造函数创建对象的过程
- 代码:
var 五类= new Person(); - 使用 new 创建一个对象, 它类似于
o = {}, 是一个没有任何成员的空对象- 使用 new 创建对象, 对象的类型就是创建他的构造函数名
- 使用 {} 创建对象, 相当于使用
new Object, 他的类型都是 Object
- 调用构造函数, 创建实例对象, 初始化成员
- 构造函数在调用的一开始, 有一个赋值操作, this指向刚刚创造错来的实例对象(引用地址)
- 隐藏在构造函数中this表示刚刚创建出来的对象
- 在构造函数中使用this结合对象的动态特性, 为实例对象添加成员
JS面向对象特性和值类型与复合类型的更多相关文章
- c++中的复合类型
复合类型是指基于其他类型而定义的类型. 而这里介绍的是引用和指针.并且指针和引用都提供了对其他对象的间接访问. 引用 引用还是很好理解的,就是为对象起了另外一个名字,引用类型引用另外一种类型. 通常将 ...
- Scala 深入浅出实战经典 第54讲:Scala中复合类型实战详解
王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-64讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 ...
- JavaScript系统学习小结——Object类型、Array类型
今天学习JavaSript中引用变量中的Object类型和Array类型: 1. Js中大多数引用类型值都是Object类型的实例,Object类型在应用程序中存储和传输数据时,是非常理想的选择: 创 ...
- 从 prototype.js 深入学习 javascript 的面向对象特性
从 prototype.js 深入学习 javascript 的面向对象特性 js是一门很强大的语言,灵活,方便. 目前我接触到的语言当中,从语法角度上讲,只有 Ruby 比它更爽. 不过我接触的动态 ...
- js中迭代元素特性与DOM中的DocumentFragment类型 笔记
JS中迭代元素特性 在需要将DOM结构序列化为XML或者HTML字符串时,多数都会涉及遍历元素的特性,这个时候attributes属性就可以派上用场. 以下代码展示了如何迭代元素的每一个特性,然后将他 ...
- 《JS权威指南学习总结--第三章类型、值和变量》
第三章 类型.值和变量 内容要点 一.数据类型 1.在编程语言中,能够表示并操作的值的类型称做数据类型 2.JS的数据类型分为两类: 原始类型:数字.字符串和布尔值 对象类型 3.JS中有两个特殊的原 ...
- JS判断时特殊值与boolean类型的转换
扒开JQuery以及其他一些JS框架源码,常常能看到下面这样的判断,写惯了C#高级语言语法的我,一直以来没能系统的理解透这段代码. var test; //do something... if(tes ...
- C#3.0新特性:隐式类型、扩展方法、自动实现属性,对象/集合初始值设定、匿名类型、Lambda,Linq,表达式树、可选参数与命名参数
一.隐式类型var 从 Visual C# 3.0 开始,在方法范围中声明的变量可以具有隐式类型var.隐式类型可以替代任何类型,编译器自动推断类型. 1.var类型的局部变量必须赋予初始值,包括匿名 ...
- Java语言中的面向对象特性总结
Java语言中的面向对象特性 (总结得不错) [课前思考] 1. 什么是对象?什么是类?什么是包?什么是接口?什么是内部类? 2. 面向对象编程的特性有哪三个?它们各自又有哪些特性? 3. 你知 ...
随机推荐
- js对象系列【二】深入理解js函数,详解作用域与作用域链。
这次说一下对象具体的一个实例:函数,以及其对应的作用域与作用域链.简单的东西大家查下API就行了,这里我更多的是分享自己的理解与技巧.对于作用域和作用域链,相信绝大多数朋友看了我的分享都能基本理解,少 ...
- Eclipse CDT开发环境搭建及问题记录(Windows)
这两天在整Eclipse,在此记录过程中遇到的一些问题. 1.安装JDK,配置系统路径: 2.下载Eclipse 直接访问Eclipse官网(https://www.eclipse.org/downl ...
- python3把txt文件转换为csv文件
#!/usr/bin/python# -*- coding: UTF-8 -*-import csvwith open('file.csv','a',newline='') as csvfile: s ...
- 【MySQL】MySQL零碎积累
MySQL零碎积累 ■ 在给MySQL添加新用户时可以这么操作: create user 'newUser' identified by 'password'; grant all privilege ...
- java设计模式-State(状态)模式
state定义 不同的状态,不同的行为;或者说,每个状态有着相应的行为. 就像电风扇的开关,一档的上一个是关闭,关闭的上一个是五档,五档的上一个是四档,以此类推,而且五档的下一 ...
- Flash Builder4.7安装破解
引用自CSDN博客,日后我会上传FlashBuilder到百度网盘谢谢 http://bbs.csdn.net/topics/391036327
- New UWP Community Toolkit - Staggered panel
概述 前面 New UWP Community Toolkit 文章中,我们对 2.2.0 版本的重要更新做了简单回顾,其中简单介绍了 Staggered panel,本篇我们结合代码详细讲解 St ...
- Python变量赋值的秘密
在Python中,我们令一个变量等于另外一个变量时,并不是把值传递给它,而是直接把指向的地址更改了.我们想要查看一个变量在内存中的地址,可以通过id(变量) 来查看.我们通过一个小例子来看看这个有趣的 ...
- 网络1711-1712的C语言作业总结(2017-2018第一学期)
1.第0次作业总结--预备作业 作业地址 1711班级总结 1712班级总结 2.第一次作业总结--顺序结构 作业地址 1711班级总结 1712班级总结 3.第二次作业总结--分支结构 作业地址 1 ...
- 从Firefox升级说学习方法
今天早上,打开PortableAPPs时,它提示我升级FireFox,跟往常一样我没考虑就升级了. 打开Firefox 57神速,很是惊喜,打开后发现悲剧了,自己(通过下载插件)定制的功能都不能使用了 ...