ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

为什么在javascript过滤中扩展数组的类的对象会调用它的构造函数?

2019-07-31 02:32:28  阅读:219  来源: 互联网

标签:derived-class javascript arrays constructor es6-class


我有这个示例代码:

class TestClass extends Array {
	constructor() {
		console.log( 'constructor' );
		
		let ar = [];
		ar.push( { id: 1, name: 'a' } );
		ar.push( { id: 2, name: 'b' } );
		ar.push( { id: 3, name: 'c' } );
		ar.push( { id: 4, name: 'd' } );
		
		// finalizing object
		super( ...ar );
	}
	
	Foo() {
		console.log( 'foo' );
		return this.filter( item => item.id > 2 );
	}
}

let t = new TestClass();
console.log( t.Foo() );

这是我已经写过的更简单的版本.我的应用程序一直工作到现在,但在我需要过滤扩展阵列中的数据时停止了.
我发现,问题是在我的类的对象上调用过滤器函数在内部调用构造函数.上面的代码显示了这个例子.
有没有办法绕过这个问题,因为我此时无法再次调用构造函数.另外,我发现(使用这个简单的TestClass)实际输出不是我所期望的 – 我得到一个包含id为3,4,3,4的4个项目的数组.任何人都可以解释这里发生了什么?

解决方法:

Symbol.species提供了一种方法来返回派生类的另一个实例,但是对于.e.g.在这种情况下,再次是一个Array实例.

class TestClass extends Array {
  constructor() {
    console.log( 'constructor' );

    let ar = [];
    ar.push( { id: 1, name: 'a' } );
    ar.push( { id: 2, name: 'b' } );
    ar.push( { id: 3, name: 'c' } );
    ar.push( { id: 4, name: 'd' } );

    // finalizing object
    super( ...ar );
  }
  static get [Symbol.species]() { return Array; }

  Foo() {
    console.log( 'foo' );
    return this.filter( item => item.id > 2 );
  }
}

let t = new TestClass();
let a = t.Foo();

console.log('a : ', a);
console.log('(a instanceof Array) ? ', (a instanceof Array));
console.log('(a instanceof TestClass) ? ', (a instanceof TestClass));
.as-console-wrapper { max-height: 100%!important; top: 0; }

标签:derived-class,javascript,arrays,constructor,es6-class
来源: https://codeday.me/bug/20190731/1586168.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有