JavaScript对象字面量和构造函数原理与用法详解


Posted in Javascript onApril 18, 2020

本文实例讲述了JavaScript对象字面量和构造函数。分享给大家供大家参考,具体如下:

对象中只有两种属性:(一种比较细的分法)

属性(数据属性)比如:名字,年龄,性别,出版社,地址等信息;
方法(封装代码的属性:函数 ,在这也是一种属性)。

在JS中对象的字面量和构造函数是非常的重点,其实在其他的语言中,是没有对象字面量的。

一.对象的字面量的语法:

{
属性名: 属性值,
属性名: 属性值,
方法名: 你们函数
}

这个大括号括起来的整个代码块就是叫做对象。

var p1 = { }

①访问对象的属性:

  1. . 语法

        对象.属性

  2. [ ] 语法

    对象["属性名"]

    对象[变量]     通过外面var一个变量,这个变量类型是字符串,然后在[]中直接使用变量名。

②修改属性的值:(当这个属性名在对象字面量中是存在的,那就是修改其值)
②修改属性的值:(当这个属性名在对象字面量中是存在的,那就是修改其值)
③新增属性的值:(当这个属性名在对象字面量中是没有的,那就是新增其属性名和属性值)

修改和新增都是一下语法:

对象.属性名 = 值

④删除对象的属性:

delete 对象.属性

二.使用构造函数来创建对象:

function Person(name, sex){
    var a = 10;
    this.name = name;
    this.sex = sex;
    this.speak = function(){

          }
    }

现在我们new一下:

var p1 = new Person ;

那么我们就叫p1是一个对象,一new出来就会在堆内存中分配一块内存空间。

那么p1的类型就是Person.

那么如果我们用 p1 instanceof Person 检测会返回true,那么 instanceof 就是测试对象类型。

在代码块中,var a = 10 ; 这个语句是一个变量,变量是放在 栈内存 ,但当他执行完一遍这个构造函数时,这个a就消失了,也就是说这个局部变量的生命周期是new出来到执行完构造函数最后一句的就消失了。

但是 里面的属性,name sex speak 这些属性上只要p1在他们就在。

那么现在我们再次体会一下局部变量a的生命周期和内存模型中的理解:

<script>
  function Person(name, sex) {
    var a = 10;
    this.name = name;
    this.sex = sex;
    this.outputa = function () {
      console.log(a);
    }
    this.speak = function () {

    }
  }

  var p1 = new Person();
  console.log(p1.a);
  p1.outputa();
</script>

结果是:

JavaScript对象字面量和构造函数原理与用法详解

首先,var p1 = new Person();,new一下出来一个p1对象,计算机就会在堆内存(heap memory)中为P1选中一块内存。

然后,console.log(p1.a);,这句语句执行,这句可以这么理解①:你a在全局变量中并没有,只在构造函数中的局部变量中才有,在构造函数中的局部变量var a = 10;他会声明提前,但是他只是提前到函数的第一行执行。这也就可以说明局部变量,我们不能在外部使用。理解②就是函数作用域中的变量他是局部变量,在栈内存分配内存后,当函数执行到最后一行时,他就结束生命周期。

这个undefined是JS的一种安全机制,如果对象点一个没有生命的变量,那么就会默认成undefined,但如果是普通的变量,就会报错。报错信息是这个变量未被定义。

详见:JavaScript内存模型详解。

*注意:对象字面量的用法用

​ 构造函数的用法用 =

那么类型和对象之间的关系是什么呢?

也就是比如p1和Person的关系是什么呢?见下表:

类型 对象
抽象 具体
其他语言中类的作用
在JS中是构造函数的形式(构造函数=类)
命名用大坨法(首字母大写)

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
asp.net 30分钟掌握无刷新 Repeater
Sep 16 Javascript
Node.js中的事件驱动编程详解
Aug 16 Javascript
jquery中one()方法的用法实例
Jan 16 Javascript
JavaScript数组迭代器实例分析
Jun 09 Javascript
Jquery组件easyUi实现表单验证示例
Aug 23 Javascript
基于Bootstrap漂亮简洁的CSS3价格表(附源码下载)
Feb 28 Javascript
bootstrap的常用组件和栅格式布局详解
May 02 Javascript
BootStrap的两种模态框方式
May 10 Javascript
基于JavaScript中字符串的match与replace方法(详解)
Dec 04 Javascript
JS实现统计字符串中字符出现个数及最大个数功能示例
Jun 04 Javascript
JavaScript数据结构与算法之二叉树遍历算法详解【先序、中序、后序】
Feb 21 Javascript
使用element-ui +Vue 解决 table 里包含表单验证的问题
Jul 17 Javascript
javascript 内存模型实例详解
Apr 18 #Javascript
javascript-hashchange事件和历史状态管理实例分析
Apr 18 #Javascript
javascript使用Blob对象实现的下载文件操作示例
Apr 18 #Javascript
原生js实现的观察者和订阅者模式简单示例
Apr 18 #Javascript
es6函数name属性功能与用法实例分析
Apr 18 #Javascript
es6数组includes()用法实例分析
Apr 18 #Javascript
es6数组的flat(),flatMap()函数用法实例分析
Apr 18 #Javascript
You might like
逆序二维数组插入一元素的php代码
2012/06/08 PHP
PHP类的声明与实例化及构造方法与析构方法详解
2016/01/26 PHP
浅谈PHP拦截器之__set()与__get()的理解与使用方法
2016/10/18 PHP
Gambit vs ForZe BO3 第三场 2.13
2021/03/10 DOTA
脚本吧 - 幻宇工作室用到js,超强推荐expand.js
2006/12/23 Javascript
浏览器无法运行JAVA脚本的解决方法
2008/01/09 Javascript
javascript 有趣而诡异的数组
2009/04/06 Javascript
IE6,IE7下js动态加载图片不显示错误
2010/07/17 Javascript
jquery重复提交请求的原因浅析
2014/05/23 Javascript
node.js中的Socket.IO使用实例
2014/11/04 Javascript
JS实现的多张图片轮流播放幻灯片效果
2016/07/22 Javascript
详解JavaScript权威指南之对象
2016/09/27 Javascript
详解Vue使用 vue-cli 搭建项目
2017/04/20 Javascript
React为 Vue 引入容器组件和展示组件的教程详解
2018/05/03 Javascript
layer.confirm取消按钮绑定事件的方法
2018/08/17 Javascript
关于vue-cli 3配置打包优化要点(推荐)
2019/04/22 Javascript
vue element实现表格合并行数据
2020/11/30 Vue.js
python实现360的字符显示界面
2014/02/21 Python
详解Python操作RabbitMQ服务器消息队列的远程结果返回
2016/06/30 Python
pycharm使用matplotlib.pyplot不显示图形的解决方法
2018/10/28 Python
对numpy中数组转置的求解以及向量内积计算方法
2018/10/31 Python
python对于requests的封装方法详解
2019/01/03 Python
Python深拷贝与浅拷贝用法实例分析
2019/05/05 Python
matplotlib图例legend语法及设置的方法
2020/07/28 Python
CSS3+DIV实现漂亮的动画彩色标签
2016/06/16 HTML / CSS
Android面试题及答案
2015/09/04 面试题
大学生职业规划范文:象牙塔生活的四年计划
2014/01/14 职场文书
八年级数学教学反思
2014/01/31 职场文书
2014年生活老师工作总结
2014/12/23 职场文书
幼师自荐信范文
2015/03/06 职场文书
教师创先争优承诺书
2015/04/27 职场文书
公司老总年会致辞
2015/07/30 职场文书
2016年中秋节寄语大全
2015/12/07 职场文书
标准演讲稿格式结尾应该怎么书写?
2019/07/17 职场文书
vue-cli4.5.x快速搭建项目
2021/05/30 Vue.js
MySQL中order by的使用详情
2021/11/17 MySQL