JavaScript 使用new关键字调用函数

简介: JavaScript 使用new关键字调用函数

使用new关键字调用函数

 

test.js

代码如下

function Person(name, age, obj) {

   var o = new Object();

   o.name = name;

   o.age=age;

   o.obj=obj;

   o.sayName=function(){

      alert(this.name);

   }

   // return o;

   //

   this.sayName=function(){

      alert(name);

   }

 

   console.log(this);

}

 

var friend=new Person("nike", 29, "software engineer");

console.log(friend);

friend.sayName();

 

 

study.html

代码如下

<!DOCTYPE html>

<html lang="zh-cn">

<head>

<meta charset="en">

</head>

<body>

<script src="test.js"></script>

</body>

</html>

 

 

运行结果

 

 

 

 

 

修改test.js代码

function Person(name, age, obj) {

   var o = new Object();

   o.name = name;

   o.age=age;

   o.obj=obj;

   o.sayName=function(){

      alert(this.name);

   }

   console.log(this);

   return o;

}

 

var friend=new Person("nike", 29, "software engineer");

console.log(friend);

friend.sayName();

 

控制台输出

 

 

 

扩展

修改test.js代码

 

定义变量,存放匿名函数的地址,然后使用该变量来调用函数

var Person = function(name, age, obj) {

   var o = new Object();

   o.name = name;

   o.age=age;

   o.obj=obj;

   o.sayName=function(){

      alert(this.name);

   }

   console.log(this);

   return o;

}

 

var friend=new Person("nike", 29, "software engineer");

console.log(friend);

friend.sayName();

 

控制台输出

同上一步结果

 

结论

1、new js函数名称(参数列表),会把对应的函数当做构造函数来使用,如果函数未定义返回值,默认的会返回通过构造函数(被调用函数)构造的对象实例;如果函数定义了返回值,则返回定义的返回值。

 

2、使用new js函数名称(参数列表)调用函数,函数中的 this 代表了新构造的对象实例。

 

3、可以直接通过定义变量,存放匿名函数的地址,然后使用该变量来调用函数

 

 

 

目录
相关文章
|
4月前
|
JavaScript 前端开发 Java
【面试题】new 一个对象时,js 做了什么?
【面试题】new 一个对象时,js 做了什么?
|
5天前
|
自然语言处理 JavaScript 前端开发
在JavaScript中,this关键字的行为可能会因函数的调用方式而异
【5月更文挑战第9天】JavaScript中的`this`关键字行为取决于函数调用方式。在非严格模式下,直接调用函数时`this`指全局对象,严格模式下为`undefined`。作为对象方法调用时,`this`指向该对象。用`new`调用构造函数时,`this`指向新实例。通过`call`、`apply`、`bind`可手动设置`this`值。在回调和事件处理中,`this`可能不直观,箭头函数和绑定方法可帮助管理`this`的行为。
11 1
|
12天前
|
JavaScript 前端开发
JavaScript 关键字
【5月更文挑战第2天】JavaScript 关键字。
19 2
|
16天前
|
JavaScript 前端开发
javascript中new关键字的本质是什么
javascript中new关键字的本质是什么
|
18天前
|
JavaScript 前端开发 数据安全/隐私保护
|
21天前
|
JavaScript 前端开发
js开发:请解释this关键字在JavaScript中的用法。
【4月更文挑战第23天】JavaScript的this关键字根据执行环境指向不同对象:全局中指向全局对象(如window),普通函数中默认指向全局对象,作为方法调用时指向调用对象;构造函数中指向新实例,箭头函数继承所在上下文的this。可通过call、apply、bind方法显式改变this指向。
8 1
|
2月前
|
JavaScript 前端开发 开发者
js开发:请解释什么是ES6的let和const关键字,以及它们与var关键字的区别。
ES6引入`let`和`const`替代`var`声明变量。`let`有块级作用域,存在暂时性死区,不进行变量提升,可重新赋值。`const`用于常量,值不可变但引用类型内容可变,同样有块级作用域和暂时性死区。与`var`主要区别在于作用域、变量提升和可变性。这些改进提高了代码的可预测性和安全性。
29 2
|
2月前
|
JavaScript 前端开发 算法
JavaScript 关键字 debugger 的作用和使用场景介绍
JavaScript 关键字 debugger 的作用和使用场景介绍
44 0
|
2月前
|
JavaScript 前端开发 编译器
编程笔记 html5&css&js 077 Javascript 关键字
编程笔记 html5&css&js 077 Javascript 关键字
|
4月前
|
存储 JavaScript 前端开发
JavaScript 自定义对象 及 new()原理与实现 如何完整地手写实现new
JavaScript 自定义对象 及 new()原理与实现 如何完整地手写实现new
70 0