什么是构造函数

简单说构造函数是类函数,函数名与类名完全相同,且无返回值。构造函数是类的一个特殊成员函数。

JavaScript构造函数

* 在JavaScript的世界里没有类的概念,JavaScript是一种基于对象的语言,它包含5中原生数据类型:number,boolean,string,null,undefined

* 除此之外,其他的所有都是对象,函数也是一个对象

* 而所谓Js中的构造函数,就是一个普通的函数,与其他函数没有任何区别,可以理解为: 构造函数==函数

* 对于Js内置对象,Object、Array、Date等等这些都是构造函数。

//有参构造函数==带参数的函数
function mod(uu) {
var test = uu;
alert(test);
}
//无参构造函数==不带参数的函数
function mod() {
var test = "初始化";
alert(test);
}

* 无参函数主要用于初始化默认值,在部分编程语言中有参函数当不传参的时候默认会有一个无参函数加载,用于初始化类函数

JavaScript构造函数的调用

* Js中使用new运算符来调用构造函数

* 一般称为类的实例化,Js中可以称为对象的实例化

* 构造函数一经实例化后,即会立即执行构造函数内的所有代码

* 而Js中所谓的构造函数与普通函数最大的区别就在于是否使用new调用

//普通函数
function mod(uu) {
var test = uu;
alert(test);
}
mod("这是一个普通函数");
//构造函数
function Mod(uu) {
var test = uu;
alert(test);
}
m = new Mod("这是一个构造函数");

* 这两个函数最终都会立即弹窗,并弹窗赋值内容,也许你会发其实都一样,然而并不是这样的。

真正的JavaScript构造函数

* 首字母大写,以区别于其他函数

* 使用关键字new调用构造函数

* 调用后自动创建this对象,且类型为构造函数类型,可以使用 instanceof 这个运算符进行校验

* 在函数内部对新对象(this)的属性进行设置,通常是添加属性和方法

* 通常没有return语句,但可以使用(不推荐),使用时返回值必须是this,或者其它非对象类型的值

* 对象有一个constructor属性,指向它的构造函数,即他返回构造函数本身

* 当方法被实例化后,构造函数会立即执行它所包含的任何代码

1、构造函数如何访问对象中的属性和方法

//构造函数访问公有变量
function Mod() {
//公有属性
this.name = "测试模板";
this.use = "可以直接通过调用对象访问"; //公有方法
this.func = function () {
console.log("公有方法也可以通过调用对象之间访问");
}
}
M = new Mod(); console.log(M.name)//Output:测试模板
console.log(M.use)//Output:可以直接通过调用对象访问
M.func();//Output:公有方法也可以通过调用对象之间访问
//构造函数访问私有变量
function Mod2() {
//私有属性
var name = "测试私有";
var use = "通常不能访问"; //私有方法
var func = function () {
console.log("与私有属性一样,通常不能访问,但可以立即执行");
} //他会立即执行
console.log(name + "----" + use);//Output:测试私有----通常不能访问
func();//Output:与私有属性一样,通常不能访问,但可以立即执行
}
M2 = new Mod2(); //却不可以被被外部所直接访问
console.log(M2.name + "----" + M2.use)//Output:undefined----undefined
M2.func();//Output:报错信息Uncaught TypeError: M2.func is not a function
//可以使用return返回私有变量,从而使得外部可以访问(不推荐)
function Mod3() {
//私有属性
var name = "测试私有";
var use = "通常不能访问"; //私有方法
var func = function () {
console.log("与私有属性一样,通常不能访问,但可以立即执行");
} //使用return返回私有变量
this.getVal = function (v) {
switch (v) {
case "n": return name;
break;
case "u": return use;
break;
case "f": return func();
break;
}
}
}
M3 = new Mod3(); console.log(M3.getVal("n") + "----" + M3.getVal("u"))//Output:测试私有----通常不能访问
M3.getVal("f");//Output:与私有属性一样,通常不能访问,但可以立即执行

2、构造函数如何为对象中的属性和方法赋值

//公有变量赋值
function Mod4(name, age, gender, text) {
this.name = name;
this.age = age;
this.gender = gender;
this.func = function () {
document.write(text);
}
}
M4 = new Mod4("leona", "18", "女", "公有变量的赋值"); console.log(M4.name + "-----" + M4.age + "-----" + M4.gender);//Output:leona-----18-----女
M4.func();//Html:公有变量的赋值
//私有变量赋值
function Mod5(name, age, gender, text) {
var name = name;
var age = age;
var gender = gender;
var func = function () {
document.write(text);
} console.log(name + "-----" + age + "-----" + gender);//Output:leona-----18-----女
func();//Html:公有变量的赋值 }
M5 = new Mod5("leona", "18", "女", "公有变量的赋值");
//我们发现我们不能从外部直接访问私有变量,但我们可以直接为其赋值

3、构造函数如何访问对象的静态变量

//访问静态变量
function Mod6() {
var name = "非静态变量";
var use = "我和name都是非静态变量,我们的生命周期存在于这个函数本身";
var func = function () {
document.write(" 我们可以直接访问静态变量,比如:");
document.write(Mod6.attr1);
document.write(Mod6.attr2);
document.write(Mod6.attr3);
document.write(Mod6.attr4 + " ");
}
func();//html:我们可以直接访问静态变量,比如:苹果香蕉芒果柚子
};
Mod6.attr1 = "苹果";
Mod6.attr2 = "香蕉";
Mod6.attr3 = "芒果";
Mod6.attr4 = "柚子";
Mod6.htmlFunc = function () {
document.write("我和attr1~4都是静态变量,我们的生命周期存在于实例化函数的整个周期");
} M6 = new Mod6(); document.write(M6.attr1);
document.write(M6.attr2);
document.write(M6.attr3);
document.write(M6.attr4);
//M6.htmlFunc();
//Html:undefinedundefinedundefinedundefined
//Output:报错信息Uncaught TypeError: M6.htmlFunc is not a function //我们发现我们并不能直接访问到构造函数的静态变量,这是因为,静态变量是通过构造函数本身去创建的变量,因此我们需要用到constructor获取到构造函数本身,从而达到访问静态变量的目的 document.write(" " + M6.constructor.attr1);
document.write(M6.constructor.attr2);
document.write(M6.constructor.attr3);
document.write(M6.constructor.attr4 + " ");
M6.constructor.htmlFunc();
//Html:苹果香蕉芒果柚子 我和attr1~4都是静态变量,我们的生命周期存在于实例化函数的整个周期

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

  1. JavaScript:学习笔记(9)——Promise对象

    JavaScript:学习笔记(9)——Promise对象 引入Promise Primose是异步编程的一种解决方案,比传统的解决方案回调函数和事件更加合理和强大.如下面为基于回调函数的Ajax操作 ...

  2. JavaScript:学习笔记(6)——New运算符

    JavaScript:学习笔记(6)——New运算符 new 运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例. 快速开始 当你使用new关键字的时候,会 创建一个新的对象 将th ...

  3. JavaScript:学习笔记(5)——箭头函数=>以及实践

    JavaScript:学习笔记(5)——箭头函数=>以及实践 ES6标准新增了一种新的函数:Arrow Function(箭头函数).本文参考的链接如下: MDN箭头函数:https://dev ...

  4. Java程序猿的JavaScript学习笔记(汇总文件夹)

    最终完结了,历时半个月. 内容包含: JavaScript面向对象特性分析,JavaScript高手必经之路. jQuery源代码级解析. jQuery EasyUI源代码级解析. Java程序猿的J ...

  5. Java程序猿的JavaScript学习笔记(8——jQuery选择器)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  6. Java程序猿JavaScript学习笔记(2——复制和继承财产)

    计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...

  7. Java程序猿的JavaScript学习笔记(3——this/call/apply)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  8. Java程序猿JavaScript学习笔记(4——关闭/getter/setter)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

  9. Java程序猿JavaScript学习笔记(14——扩大jQuery UI)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

随机推荐

  1. Android Unique Device ID

    There are several occasions when the unique identifier of a device is required. For instance you nee ...

  2. js+CSS 实现可以编辑的下拉列表框

    <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="C ...

  3. Mac 全局变量 ~/.bash_profile 文件不存在的问题

    不存在就新建呗~ $ cd ~/ $ touch .bash_profile $ open -e .bash_profile 然后输入以下内容 # set color的部分是配置iterm2的字体颜色 ...

  4. ss - float浮动模块的高度问题 解决方案

    当一个Div中的子元素都是浮动元素时,该div是没有高度的.通常会带来很多困扰,解决方案如下: 低版本统配兼容: overflow: hidden; 下面是不支持低配浏览器,而且似乎该效果对 P 标签 ...

  5. FreeSWITCH小结:关于export的原理介绍及应用

    FreeSWITCH小结:关于export的原理介绍及应用 Export原理 普通export用法 在dialplan中经常会用到export,如下所示: <action application ...

  6. 【转载】Oracle数据字典详解

    转自:http://czmmiao.iteye.com/blog/1258462 Oracle数据字典概述 数据库是数据的集合,数据库维护和管理这用户的数据,那么这些用户数据表都存在哪里,用户的信息是 ...

  7. JVM性能调优入门

    1. 背景 虽然大多数应用程序使用JVM的默认设置就能很好地工作,仍然有不少应用程序需要对JVM进行额外的配置才能达到其期望的性能要求. 现在JVM为了满足各种应用的需要,为程序运行提供了大量的JVM ...

  8. [Egret]长按截屏分享、分享截屏图片、本地存储

    egret 分享有API可以把一个显示对象树渲染成一个位图纹理,我把它赋值给 HTML 的 Image 元素,就实现了图片的显示,在微信中,通过长按图片可以分享出去.当然在其他浏览器可以保存在本地. ...

  9. linux系统的开机引导、启动流程

    固件(CMOS/BIOS) > POST 加电自检 ↓ 自举程序(GRUB)> 加载内核 ↓ 载入内核 > 驱动硬件 ↓ 启动进程 init ↓ 读取执行配置文件/etc/initt ...

  10. hMailServer之允许用户自己修改密码

    使用hMailServer搭建邮件系统,使用webmail实现web收发邮件,但是又个问题是在webmail中用户自己无法修改密码. 可以使用hMailServer自带的PhpWebAdmin来实现让 ...