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、可以直接通过定义变量,存放匿名函数的地址,然后使用该变量来调用函数

 

 

 

posted @   授客  阅读(1141)  评论(0编辑  收藏  举报
编辑推荐:
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
阅读排行:
· 【.NET】调用本地 Deepseek 模型
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
点击右上角即可分享
微信分享提示