Сообщение от JS_Johny
|
у встроенных конструкторов Object и Function одинаковый прототип
|
У них одинаковый конструктор. Конструктором у конструкторов Object и Function является конструктор Function. Да, Object и Function — это функции, вы их можете вызывать.
alert(Function.constructor === Object.constructor)
alert(Function.constructor === Function)
Мы можем рассматривать Object, Function, и другие классы, например, Array или собственный класс Person, как представителей класса Function.
Например, класс Person можно описать так...
function Person(name, age) {
this.name = name;
this.age = age;
}
и такой класс тоже является представителем класса Function. Ведь такая запись является, в некотором смысле, синтаксическим сахаром для следующего кода...
var Person = new Function("name", "age", "this.name = name; this.age = age;");
По умолчанию все классы наследуют от Object. Например, рассмотрев массив, мы увидим, что он является представителем класса Array и наследует от Object.
alert(["a","b"].constructor)// на самом деле оно пошло смотреть ["a","b"].__proto__.constructor
alert(["a","b"].__proto__.constructor)
alert(["a","b"].__proto__.__proto__.constructor)
alert(["a","b"] instanceof Array && ["a","b"] instanceof Object)
Но мы можем захотеть не наследовать от Object, вообще не наследовать.
function Empty() {}
Empty.prototype = {
constructor: Empty,
__proto__: null
};
// если взглянуть в консоль, то видно, что у представителя класса Empty нет свойств, которые обычно наследуются от Object
console.log(new Empty());
Сообщение от JS_Johny
|
У Function вообще .__proto__ и .prototype содержат ссылку на один и тот же объект
|
да, поскольку Function является представителем класса Function
alert(Function.prototype === Function.__proto__);
alert(Function.__proto__.constructor === Function);
alert(Function instanceof Function === true)
Сообщение от JS_Johny
|
Почему... Function.prototype — функция?
|
Его конструктор — функция. Т. е. если мы создадим представителя класса функции, то мы получим функцию!
Вот схема, показывающая, отношения объекта и функции.
Чтобы узнать собственные свойства объекта, используйте статичный метод Object.getOwnPropertyNames
console.log(Object.getOwnPropertyNames(["a","b"]));
Чтобы посмотреть, на что ссылается внутреннее свойство [[Prototype]], используйте статичный метод Object.getPrototypeOf
console.log(Object.getOwnPropertyNames(Object.getPrototypeOf(["a","b"])));
Сообщение от Aetae
|
Смотреть __proto__ у встроенных классов никакого смысла нет, т.к. там всегда будет одно и то же.
|
Посмотрите типизированные массивы, генераторы, асинхронные функции, т. е. они не наследуют напрямую от Object.
console.log(Uint16Array.prototype.__proto__.constructor);
console.log(Float64Array.prototype.__proto__.constructor);
console.log((function*(){}).constructor.prototype.__proto__.constructor);
console.log((async function*(){}).constructor.prototype.__proto__.constructor);
console.log((async ()=>{}).constructor.prototype.__proto__.constructor);