Object——引用数据类型

基本数据类型的不足之处:基本数据类型是单一的值,不能表现出值与值之间的所属关系

object分为内建对象、宿主对象和自定义对象

a 内建对象:ES标准中定义的对象,在任何ES的实现中都可以使用;例如:Math  String等。

b 宿主对象:由JS运行的浏览器提供的对象,目前主要是指浏览器提供的对象;例如:BOM DOM.

c自定义对象:由开发人员自己创建的对象。

属性名和属性值

例如,先创建一个新的对象 var obj = newObject(); 向新创建的对象中添加属性 obj.name =“陈飘”;

此时这里的name为属性名 “陈飘”为属性值

注意:

a 属性名不强制遵守标识符规范,但是尽量遵守标识符的规范,如果使用了特殊的属性名,则不可以使用 object.属性名=属性值的方式添加对象属性,需要使用 object["属性名“]=属性值,同时在取读时也需要使用该方式。

b属性值可以是任意数据类型,甚至可以是一个对象。

c in运算符:通过这个运算符可以检查一个对象是否含有指定的属性,如果有则返回true,否则返回false。

语法: ”属性名“in obj

例如:console.log("test" in obj);

关于属性的总结:

添加属性 :obj.属性名=属性值;

取读属性:obj.属性名  例如:console.log(obj.gender); 注意:如果没有该属性会返回undefined并不会报错。

修改属性:obj.属性名=新的属性值;

删除属性:delete obj.属性名

基本数据类型和引用数据类型的区别:

基本数据类型:String  Boolean  Number Undfined   Null

引用数据类型:Object

区别:

基本数据类型:js的变量保存在栈内存中,变量的值也是直接保存在栈内存中;值与值之间是彼此独立的,一个值的修改仅仅影响自身。

var a =12; var  b = a;  a++;

以上 输出 a = 13  b=12   两者是互不影响的

变量在栈内存中保存显示    变量名+值

引用数据类型:创建一个对象时会在堆内存中开辟一个空间,用来存放对象的属性。在为对象添加属性时,是将属性放在堆内存中开辟的空间里。

在栈内存中保存显示  对象名 +一个地址(类似于指针,指向堆内存中该对象开辟的空间)

var obj = New object();  obj.name="陈飘";    var obj2 = obj; obj2.name =“阿飘”;

此时name=阿飘。值已经被修改,因为两个对象指向同一个地址

注意 当obj2.name= Null; 时  name= 陈飘   切断了该对象和地址的联系。

Object 对象(对象的分类、属性(属性名和属性值)、基本数据类型与引用数据类型区别)的更多相关文章

  1. C#基础(204)--对象初始化器,基本数据类型与引用数据类型特点总结,ref,out关键字的使用

    对象初始化器: 对象在创建过程中也可以使用对象初始化器完成“属性的初始化” Student stu =new Student(){ StudentId=, StudentName="张三&q ...

  2. C# static 字段初始值设定项无法引用非静态字段、方法或属性

    问题:字段或属性的问题字段初始值设定项无法引用非静态字段.方法 下面代码出错的原因,在类中定义的字段为什么不能用? public string text = test(); //提示 字段或属性的问题 ...

  3. js中对象的属性名和属性值

    代码 /** * 对象的属性名 * - 对象的属性名不强制遵循标识符的命名规范,可以是任意的名字,但在开发中 * 尽量遵循标识符的命名规范 */ // 创建对象obj1 var obj1 = new ...

  4. Object.assign()的用法 -- 用于将所有可枚举属性的值从一个或多个源对象复制到目标对象,返回目标对象

    语法: Object.assign(target, …sources) target: 目标对象,sources: 源对象用于将所有可枚举属性的值从一个或多个源对象复制到目标对象.它将返回目标对象. ...

  5. vue2.x版本中Object.defineProperty对象属性监听和关联

    前言 在vue2.x版本官方文档中 深入响应式原理 https://cn.vuejs.org/v2/guide/reactivity.html一文的解释当中,Object.defineProperty ...

  6. ES6扩展——对象的扩展(简洁表示法与属性名表达式)

    1.简洁表达法. 当属性名与属性值相同时,可省略属性值:例如:{name : name}可以写成 {name} 属性方法中,可省略冒号与function,直接 属性名(){}即可.例如{say : f ...

  7. 一个高性能的对象属性复制类,支持不同类型对象间复制,支持Nullable<T>类型属性

    由于在实际应用中,需要对大量的对象属性进行复制,原来的方法是通过反射实现,在量大了以后,反射的性能问题就凸显出来了,必须用Emit来实现. 搜了一圈代码,没发现适合的,要么只能在相同类型对象间复制,要 ...

  8. js对象的属性:数据(data)属性和访问器(accessor)属性

    此文为转载,原文: 深入理解对象的数据属性与访问器属性 创建对象的方式有两种:第一种,通过new操作符后面跟Object构造函数,第二种,对象字面量方式.如下 var person = new Obj ...

  9. Python笔记_第三篇_面向对象_8.对象属性和类属性及其动态添加属性和方法

    1. 对象属性和类属性. 我们之前接触到,在类中,我们一般都是通过构造函数的方式去写一些类的相关属性.在第一次介绍类的时候我们把一些属性写到构造函数外面并没有用到构造函数,其实当时在写的时候,就是在给 ...

随机推荐

  1. 前世今生:Hive、Shark、spark SQL

    Hive (http://en.wikipedia.org/wiki/Apache_Hive )(非严格的原文顺序翻译)  Apache Hive是一个构建在Hadoop上的数据仓库框架,它提供数据的 ...

  2. Vue踩坑系列

    前言 前端开发对于vue的使用已经越来越多,它的优点就不做介绍了, 本篇是我对vue使用过程中遇到的问题中做的一些总结,帮助大家踩坑.如果喜欢的话可以点波赞,或者关注一下,希望本文可以帮到大家!!! ...

  3. 浅谈 Nginx和LVS的各种优缺点

    VS的负载能力强,因为其工作方式逻辑非常简单,仅进行请求分发,而且工作在网络的第4层,没有流量,所以其效率不需要有过多的忧虑. LVS基本能支持所有应用,因为工作在第4层,所以LVS可以对几乎所有应用 ...

  4. Python学习笔记:Unittest框架了解

    Unittest单元测试框架不仅可以适用于单元测试,还可以适用于自动化测试用来的开发与执行,该测试框架可执行测试用例,并提供丰富的断言方法,最终生成测试报告. 一.Unittest常用方法 1.Tes ...

  5. python 学习笔记(一):在列表、字典、集合中根据条件筛选数据

    一.在列表中筛选数据 在列表中筛选出大于等于零的数据,一般通用的用法代码如下: data = [3, -9, 0, 1, -6, 3, -2, 8, -6] #要筛选的原始数据列表 result = ...

  6. idea 错误: 找不到或无法加载主类 xxx.xxx.xxxxx

    idea 错误: 找不到或无法加载主类 xxx.xxx.xxxxx JDK环境,maven项目还是ee还是web项目,是否都正常. 如果是用idea打开的话,在源码目录上点击右键,然后找到Mark d ...

  7. CTF攻防练习之综合训练1

    主机:192.168.32.152 靶机:192.168.32.166 首先使用nmap,nikto -host ,dirb扫描,探测靶场开放了 21,22,80d端口已经发现有一下关键信息 进入lo ...

  8. jQuery I

    jQuery 两大特点: 链式编程:比如.show()和.html()可以连写成.show().html(). 隐式迭代:隐式对应的是显式.隐式迭代的意思是:在方法的内部进行循环遍历,而不用我们自己再 ...

  9. VIM全总结

    Vim是Linux自带的编辑器,是Vi的高级版,刚开始使用我是一脸懵逼的,跟普通的编辑器完全不同,基本全靠键盘,写完之后也不知道怎么保存,特地花了点时间了解了一下,还是挺简单的.其中,主要包含三种模式 ...

  10. python笔记之列表

    python中列表使用list类. 创建一个列表:list1 = [1,2,3,4]使用逗号隔开每个元素,使用方括号包含起来,创建空列表直接使用list2 = [] #!/usr/bin/env py ...