构造函数

构造函数就是一个普通的函数,创建方式和普通函数没有区别

不同的是构造函数名习惯上首字母大写

普通函数是直接调用,而构造函数需要使用new关键字来调用

  • 构造函数的执行流程:
  1. 立刻创建一个新的对象
  2. 将新建的对象设置为函数中的this(在构造函数中可以使用this来引用新建的对象)
  3. 逐行执行函数中的代码
  4. 将新建的对象作为返回值返回

使用同一个构造函数创建的对象,我们称为一类对象,也将一个构造函数称为一个类

​ 我们将通过一个函数创建的对象,称为是该类的实例

/* 创建一个Person构造函数
* - 在Person构造函数中,为每一个对象都添加了一个sayName方法
* 目前我们是在构造函数内部创建方法,这就导致了构造函数每执行一次就会创建一个方法
* 而且所有实例的sayName方法都是一模一样的但却是唯一的
* - 我们完全可以使所有对象共享一个方法
*/
function Person(name, age, gender){
this.name = name;
this.age = age;
this.gender = gender;
//1.在构造函数内部添加方法
/*this.sayName = function(){
alert("大家好,我是"+this.name);
};*/
//this.sayName = fun; //2.将sayName方法在全局作用域中定义,而不是在构造函数内部
} //将sayName方法在全局作用域中定义
/*
* 将函数定义在全局作用域,污染了全局作用域的命名空间
* 而且定义在全局作用域中也很不安全
* 解决:原型
*/
//function fun(){
// alert("大家好,我是"+this.name);
//} //3.向原型中添加sayName方法
Person.prototype.sayName = function(){
alert("大家好,我是"+this.name);
}; //创建Person类的实例
var person1 = new Person("李四", 18, "男");
var person2 = new Person("王五", 16, "女"); person1.sayName();
person2.sayName(); //使用instanceof可以检查一个对象是否是一个类的实例
//console.log(person1 instanceof Person); //true /*
* 所有对象都是Object的后代
* 所以任何对象和Object作instanceof检查时都会返回true
*/
//console.log(person1 instanceof Object); //true

原型

/*
* 原型prototype
* 我们所创建的每一个函数,解析器都会向函数中添加一个属性prototype
* 这个属性对应着一个对象,这个对象就是我们所谓的原型对象
* 如果函数作为普通函数调用prototype没有任何作用
* 当函数以创造函数的形式调用时,它所创建的对象中都会有一个隐含的属性
* 指向该构造函数的原型对象,我们可以通过__proto__来访问
*
* 原型对象就相当于一个公共的区域,所有同一个类的实例都可以访问到
* 我们可以将对象中共有的内容,统一设置到原型对象中
*
* 当我们访问对象的属性或方法时,会现在对象自身中寻找,如果有则直接使用,
* 没有则去原型中寻找... 直到找到Object的原型
* Object的原型没有原型(null),如果在Object的原型中依然没有找到,则返回undefined
*
* 以后我们创建构造函数时,可以将这些对象共有的属性和方法,添加到构造函数的原型对象中
*/
function MyClass(){ } //向MyClass的原型中添加属性a
MyClass.prototype.a = 123; //向MyClass的原型中添加方法
MyClass.prototype.sayHello = function(){
alert("Hello");
}; var mc = new MyClass();
var mc2 = new MyClass(); mc2.a = "我是mc2中的a"; //console.log(MyClass.prototype);
//console.log(mc.__proto__ == MyClass.prototype); //true console.log(mc.a); //123
console.log(mc2.a); //我是mc2中的a
function MyClass(){

}

//向MyClass的原型中添加属性name
MyClass.prototype.name = "我是原型中的名字"; var mc = new MyClass();
mc.age = 18; //使用in检查对象中是否含有某个属性时,如果对象中没有但是原型中有,也会返回true
//console.log("name" in mc); //true //可以使用hasOwnProperty()来检查对象自身中是否有该属性
//使用该方法只有当对象自身含有该属性时,才会返回true
console.log(mc.hasOwnProperty("name")); //false
console.log(mc.hasOwnProperty("age")); //true

JavaScript构造函数学习笔记分享的更多相关文章

  1. JavaScript构造函数学习笔记

    1 理解Javascript constructor实现原理 在 JavaScript 中,每个函数都有名为“prototype”的属性,用于引用原型对象.此原型对象又有名为“constructor” ...

  2. javascript正则表达式 - 学习笔记

    JavaScript 正则表达式 学习笔记 标签(空格分隔): 基础 JavaScript 正则表达式是用于匹配字符串中字符组合的模式.在javascript中,正则表达式也是对象.这些模式被用于Re ...

  3. JavaScript正则表达式学习笔记(二) - 打怪升级

    本文接上篇,基础部分相对薄弱的同学请移步<JavaScript正则表达式学习笔记(一) - 理论基础>.上文介绍了8种JavaScript正则表达式的属性,本文还会追加介绍几种JavaSc ...

  4. JavaScript简易学习笔记

    学习地址:http://www.w3school.com.cn/js/index.asp 文字版: https://github.com/songzhenhua/github/blob/master/ ...

  5. javaScript 对象学习笔记

    javaScript 对象学习笔记 关于对象,这对我们软件工程到学生来说是不陌生的. 因为这个内容是在过年学到,事儿多,断断续续,总感觉有一丝不顺畅,但总结还是要写一下的 JavaScript 对象 ...

  6. 学习笔记分享之汇编---3. 堆栈&标志寄存器

    前言:   此文章收录在本人的<学习笔记分享>分类中,此分类记录本人的学习心得体会,现全部分享出来希望和大家共同交流学习成长.附上分类链接:   https://www.cnblogs.c ...

  7. 【MarkMark学习笔记学习笔记】javascript/js 学习笔记

    1.0, 概述.JavaScript是ECMAScript的实现之一 2.0,在HTML中使用JavaScript. 2.1 3.0,基本概念 3.1,ECMAScript中的一切(变量,函数名,操作 ...

  8. Javascript MVC 学习笔记(一) 模型和数据

    写在前面 近期在看<MVC的Javascript富应用开发>一书.本来是抱着一口气读完的想法去看的.结果才看了一点就傻眼了:太多不懂的地方了. 仅仅好看一点查一点,一点一点往下看吧,进度虽 ...

  9. Javascript作用域学习笔记(三)

    看完<你不知道的javascript>上,对作用域的新的理解(2018-9-25更) 一.学习笔记:   1.javascript中的作用域和作用域链 +  每个函数在被调用时都会创建一个 ...

随机推荐

  1. bash:echo

    echo 'xxxx'自带换行 echo -n ‘xxxxxx’ 取消换行 echo -e "xxxxxxxxxxxx"允许转义字符(两种引号对转以字符效果相同,影响$变量) 转义 ...

  2. 学习记录:《C++设计模式——李建忠主讲》6.“状态变化”模式

    状态变化模式:在组件构建过程中,某些对象的状态经常面临变化,如何对这些变化进行有效的管理?同时又维持高层模块的稳定.状态变化模式为这一问题提供了一种解决方案. 典型模式:状态模式(State).备忘录 ...

  3. JavaWeb04-JSP及会话跟踪技术

    JSP入门 1 JSP概述 1.1 什么是JSP JSP(Java Server Pages)是JavaWeb服务器端的动态资源.它与html页面的作用是相同的,显示数据和获取数据. 1.2 JSP的 ...

  4. Java面向基础概述和三大特性

    Java 是面向对象的高级编程语言,类和对象是 Java 程序的构成核心.围绕着 Java 类和 Java 对象,有三大基本特性:封装是 Java 类的编写规范.继承是类与类之间联系的一种形式.而多态 ...

  5. PowerMock学习(九)之Mock Answer的使用

    关于Mock Answer 上一篇文章,有介绍过关于Arguments Matche的使用,其实 Answer的作用与其比较类似,但是它比 Arguments Matcher 更加强大. Argume ...

  6. Xtrabackup 安装 参数详解

    目录 安装 常用参数详解 innobackupex 相关参数 xtrabackup相关参数 安装 继Xtrabackup 介绍,本次来讲解安装和使用. Xtrabackup的RPM包下载地址: 系统版 ...

  7. 3、Docker 基础安装和基础使用 二

    Docker 网络 启动了nginx容器,但却不知道从哪里进行访问nginx. 启动nginx容器,并附加网络映射 在启动nginx容器的时候,增加一个-P大写的P的参数 表示随机映射一个端口 [ro ...

  8. JavaScript的定时器是如何工作的

    理解JavaScript定时器工作原理对于学习JavaScript非常重要.因为JavaScript是单线程运行的,定时器使用场合少,不是很直观.下面通过三个函数来学习JavaScript如何定义,操 ...

  9. Spring Cloud Gateway - 路由法则

    1. After Route Predicate Factory 输入一个参数:时间,匹配该时间之后的请求,示例配置: spring: cloud: gateway: routes: - id: af ...

  10. 八大机器学习框架对比及Tensorflow的优势

    八大机器学习框架的对比: (1)  TensorFlow:深度学习最流行的库之一,是谷歌在深刻总结了其 前身 DistBelief 的经验教训上形成的:它不仅便携.高效.可扩 展,还能再不同计算机上运 ...