Baseline Widely available
Die name
Dateneigenschaft einer Function
Instanz gibt den Namen der Funktion an, wie er beim Erstellen angegeben wurde, oder sie kann entweder anonymous
oder ''
(ein leerer String) sein, wenn Funktionen anonym erstellt wurden.
const func1 = function () {};
const object = {
func2: function () {},
};
console.log(func1.name);
// Expected output: "func1"
console.log(object.func2.name);
// Expected output: "func2"
Wert
Ein String.
Schreibbar nein Aufzählbar nein Konfigurierbar jaHinweis: In nicht-standardmäÃigen, Pre-ES2015 Implementierungen war das configurable
Attribut ebenfalls false
.
Die name
-Eigenschaft der Funktion kann verwendet werden, um die Funktion in Debugging-Werkzeugen oder Fehlermeldungen zu identifizieren. Sie hat keine semantische Bedeutung für die Sprache selbst.
Die name
-Eigenschaft ist schreibgeschützt und kann nicht durch den Zuweisungsoperator geändert werden:
function someFunction() {}
someFunction.name = "otherFunction";
console.log(someFunction.name); // someFunction
Um sie zu ändern, verwenden Sie Object.defineProperty()
.
Die name
-Eigenschaft wird typischerweise basierend darauf abgeleitet, wie die Funktion definiert ist. In den folgenden Abschnitten beschreiben wir die verschiedenen Möglichkeiten, wie sie abgeleitet werden kann.
Die name
-Eigenschaft gibt den Namen einer Funktionsdeklaration zurück.
function doSomething() {}
doSomething.name; // "doSomething"
Standard-exporierte Funktionsdeklaration
Eine export default
Deklaration exportiert die Funktion als Deklaration anstelle eines Ausdrucks. Wenn die Deklaration anonym ist, ist der Name "default"
.
// -- someModule.js --
export default function () {}
// -- main.js --
import someModule from "./someModule.js";
someModule.name; // "default"
Funktionskonstruktor
Funktionen, die mit dem Function()
Konstruktor erstellt werden, haben den Namen "anonymous".
new Function().name; // "anonymous"
Funktionsausdruck
Wenn der Funktionsausdruck benannt ist, wird dieser Name als name
-Eigenschaft verwendet.
const someFunction = function someFunctionName() {};
someFunction.name; // "someFunctionName"
Anonyme Funktionsausdrücke, die entweder mit dem function
-Schlüsselwort oder der Pfeilfunktionssyntax erstellt wurden, haben standardmäÃig ""
(einen leeren String) als Namen.
(function () {}).name; // ""
(() => {}).name; // ""
Solche Fälle sind jedoch selten â normalerweise wird, um die Funktion anderswo aufzurufen, der Funktionsausdruck mit einem Bezeichner verknüpft. Der Name eines anonymen Funktionsausdrucks kann innerhalb bestimmter syntaktischer Kontexte abgeleitet werden, einschlieÃlich: Variablendeklaration, Methode, Initialisierung und Standardwert.
Ein praktischer Fall, in dem der Name nicht abgeleitet werden kann, ist eine Funktion, die aus einer anderen Funktion zurückgegeben wird:
function getFoo() {
return () => {};
}
getFoo().name; // ""
Variablendeklaration und Methode
Variablen und Methoden können den Namen einer anonymen Funktion aus ihrer syntaktischen Position ableiten.
const f = function () {};
const object = {
someMethod: function () {},
};
console.log(f.name); // "f"
console.log(object.someMethod.name); // "someMethod"
Dasselbe gilt für die Zuweisung:
let f;
f = () => {};
f.name; // "f"
Initialisierung und Standardwert
Funktionen in Initialisierungen (Standardwerten) von Destrukturierungen, Standardparametern, Klassenfeldern usw. erben den Namen des gebundenen Bezeichners als ihren name
.
const [f = () => {}] = [];
f.name; // "f"
const { someMethod: m = () => {} } = {};
m.name; // "m"
function foo(f = () => {}) {
console.log(f.name);
}
foo(); // "f"
class Foo {
static someMethod = () => {};
}
Foo.someMethod.name; // someMethod
Verkuerzte Methode
const o = {
foo() {},
};
o.foo.name; // "foo";
Gebundene Funktion
Function.prototype.bind()
erzeugt eine Funktion, deren Name "bound " plus der Funktionsname ist.
function foo() {}
foo.bind({}).name; // "bound foo"
Getter und Setter
Wenn Zugriffseigenschaften get
und set
verwendet werden, erscheint "get" oder "set" im Funktionsnamen.
const o = {
get foo() {
return 1;
},
set foo(x) {},
};
const descriptor = Object.getOwnPropertyDescriptor(o, "foo");
descriptor.get.name; // "get foo"
descriptor.set.name; // "set foo";
Klasse
Der Name einer Klasse folgt dem gleichen Algorithmus wie Funktionsdeklarationen und -ausdrücke.
class Foo {}
Foo.name; // "Foo"
Warnung: JavaScript setzt die name
-Eigenschaft einer Funktion nur, wenn sie keine eigene Eigenschaft namens name
hat. Klassen' statische Mitglieder werden jedoch als eigene Eigenschaften der Klassenkonstruktorfunktion festgelegt und verhindern somit, dass der eingebaute name
angewendet wird. Siehe ein Beispiel unten.
Wenn ein Symbol
als Funktionsname verwendet wird und das Symbol eine Beschreibung hat, ist der Methodenname die Beschreibung in eckigen Klammern.
const sym1 = Symbol("foo");
const sym2 = Symbol();
const o = {
[sym1]() {},
[sym2]() {},
};
o[sym1].name; // "[foo]"
o[sym2].name; // "[]"
Private Felder und Methoden
Private Felder und private Methoden haben das Rautezeichen (#
) als Teil ihrer Namen.
class Foo {
#field = () => {};
#method() {}
getNames() {
console.log(this.#field.name);
console.log(this.#method.name);
}
}
new Foo().getNames();
// "#field"
// "#method"
Beispiele Den Namen des Konstruktors eines Objekts ermitteln
Sie können obj.constructor.name
verwenden, um die "Klasse" eines Objekts zu überprüfen.
function Foo() {} // Or: class Foo {}
const fooInstance = new Foo();
console.log(fooInstance.constructor.name); // "Foo"
Da jedoch statische Mitglieder zu eigenen Eigenschaften der Klasse werden, können wir den Klassenname für praktisch jede Klasse mit einer statischen Methodeneigenschaft name()
nicht erhalten:
class Foo {
constructor() {}
static name() {}
}
Mit einer static name()
Methode hält Foo.name
nicht mehr den tatsächlichen Klassennamen, sondern eine Referenz auf das name()
Funktionsobjekt. Der Versuch, die Klasse von fooInstance
über fooInstance.constructor.name
zu erhalten, gibt uns nicht den Klassennamen, sondern eine Referenz auf die statische Klassenmethode. Beispiel:
const fooInstance = new Foo();
console.log(fooInstance.constructor.name); // Æ name() {}
Aufgrund der Existenz statischer Felder könnte name
ebenfalls keine Funktion sein.
class Foo {
static name = 123;
}
console.log(new Foo().constructor.name); // 123
Wenn eine Klasse eine statische Eigenschaft namens name
hat, wird sie auch beschreibbar. Die eingebaute Definition in der Abwesenheit einer benutzerdefinierten statischen Definition ist schreibgeschützt:
Foo.name = "Hello";
console.log(Foo.name); // "Hello" if class Foo has a static "name" property, but "Foo" if not.
Daher können Sie sich nicht darauf verlassen, dass die eingebaute name
-Eigenschaft immer den Namen einer Klasse enthält.
Warnung: Seien Sie vorsichtig bei der Verwendung der name
-Eigenschaft mit Quellcode-Transformationen, wie sie von JavaScript-Komprimierern (Minifizierern) oder Obfuskatoren durchgeführt werden. Diese Werkzeuge werden oft im Rahmen einer JavaScript-Build-Pipeline verwendet, um die GröÃe eines Programms vor der Bereitstellung in der Produktion zu reduzieren. Solche Transformationen ändern oft den Namen einer Funktion zur Build-Zeit.
Quellcode wie:
function Foo() {}
const foo = new Foo();
if (foo.constructor.name === "Foo") {
console.log("'foo' is an instance of 'Foo'");
} else {
console.log("Oops!");
}
kann komprimiert werden zu:
function a() {}
const b = new a();
if (b.constructor.name === "Foo") {
console.log("'foo' is an instance of 'Foo'");
} else {
console.log("Oops!");
}
In der unkomprimierten Version läuft das Programm in den truthy-Zweig und protokolliert "'foo' is an instance of 'Foo'" â während es in der komprimierten Version anders reagiert und in den else-Zweig läuft. Wenn Sie sich auf die name
-Eigenschaft verlassen, wie im obigen Beispiel, stellen Sie sicher, dass Ihre Build-Pipeline die Funktionsnamen nicht ändert, oder verlassen Sie sich nicht darauf, dass eine Funktion einen bestimmten Namen hat.
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4