javascript中new function()的返回值,同时利用return的返回不同的结果

只要new function()的function有返回值的话那么就应该返回function返回值,但是事实上呢?看下边的例子

js 代码
  1. function fn()   
  2. {   
  3.     this.k = 1;   
  4.     return 1;   
  5. }   
  6. fn.prototype = {   
  7.     j: 0   
  8. };   
  9. var f = new fn();  //  f = {}  

结果出乎意料,竟然是fn的实例({k:1, j:0});为什么又是function的实例了?继续看下面的实验,在fn中分别return各种数据类型的值,得出一下结果

js 代码
  1. return 1;                   f = {"j":0,"k":1}    
  2. return false;               f = {"j":0,"k":1}    
  3. return true;                f = {"j":0,"k":1}    
  4. return "string";            f = {"j":0,"k":1}    
  5. return null;                f = {"j":0,"k":1}    
  6. return undefined;           f = {"j":0,"k":1}    
  7.   
  8.   
  9. return new Number(1);           f = 值为1的Number对象   
  10. return new String("string");    f = 值为"string"的String对象   
  11. return new Boolean(true);       f = 值为true的对象  
  12. return [1];                       f = [1]   
  13. return new Object();            f = {}  

[修正]Boolean是有定义的,ToString()应该是toString();

实验的结论很明显,如果function的返回值是对象的话则返回该对象,否则返回function的实例

 

再举一个例子:

 

 1 var fn = function(){
2 this.k=1;
3 var privateFun = function(){ };
4 return {
5 publicFun: function() {
6 privateFun();
7 }
8 };
9 }
10 fn.prototype = {
11 j: 0
12 };
13 var fntest1 = new fn();
14 var fntest2 = fn();
15
16 // alert(fntest1);alert(fntest2); 监视时只会看到方法(publicFun),不会看到方法(privateFun)
17 //
18
19 var c=1;

 

 

 

 

转载于:https://www.cnblogs.com/pctzhang/archive/2011/12/08/2280315.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript,当你使用`return new Promise`创建一个新的Promise实例时,这个Promise会在异步操作完成后返回一个值。要获取这个返回值,你需要通过`.then`方法处理Promise链。这里的"返回值"通常指的是异步操作执行后Promise的`resolve`函数传入的值。 以下是一个简单的例子: ```javascript function asyncFunction() { return new Promise((resolve, reject) => { // 模拟异步操作,这里我们用一个简单的setTimeout setTimeout(() => { const result = '这是一个返回值'; resolve(result); // 当异步操作成功,调用resolve并传入结果 }, 1000); }); } asyncFunction().then((value) => { console.log('Promise的返回值:', value); // 在这里,你会看到异步操作完成后的返回值 }).catch((error) => { console.error('Promise执行失败:', error); }); ``` 在上面的代码,`.then`方法接收一个回调函数,这个函数会在Promise状态变为fulfilled(成功)时被调用,参数就是`resolve`函数传入的值。如果Promise在执行过程遇到错误,`.catch`方法会捕获这个错误。 如果你想要在当前作用域直接使用返回值,可以考虑使用`async/await`来简化代码: ```javascript async function asyncFunction() { return new Promise((resolve, reject) => { setTimeout(() => { resolve('这是一个返回值'); }, 1000); }); } async function main() { try { const result = await asyncFunction(); console.log('Promise的返回值:', result); } catch (error) { console.error('Promise执行失败:', error); } } main(); ``` 在这个版本,`asyncFunction`内部的Promise会被自动解析,然后你可以直接使用`await`关键字获取返回值

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值