Maison >interface Web >js tutoriel >Comment tracer les détails de la fonction de l'appelant (numéro de ligne et URL source) en JavaScript ?

Comment tracer les détails de la fonction de l'appelant (numéro de ligne et URL source) en JavaScript ?

Barbara Streisand
Barbara Streisandoriginal
2024-10-20 21:53:30902parcourir

How to Trace Caller Function Details (Line Number and Source URL) in JavaScript?

Traçage des détails de l'appelant en JavaScript : numéro de ligne et URL source

Pour retrouver les détails de la fonction de l'appelant, y compris le numéro de ligne et l'URL source, envisagez l'approche suivante :

Obtention du nom de la fonction de l'appelant :

<br>var callerFunc = arguments.callee.caller.toString();<br>callerFuncName = (callerFunc.substring(callerFunc.indexOf("function") 8, callerFunc.indexOf("(")) || "anoynmous")<br>

Ce code L'extrait obtient le nom de la fonction appelante.

Récupération du numéro de ligne de l'appelant :

Pour obtenir le numéro de ligne à partir duquel la fonction de l'appelant a été invoquée :

function getErrorObject() {
    try {
        throw Error('');
    } catch (err) {
        return err;
    }
}

var err = getErrorObject();
var caller_line = err.stack.split("\n")[4];
var index = caller_line.indexOf("at ");
var clean = caller_line.slice(index + 2, caller_line.length);

Cette méthode exploite la propriété de pile de l'objet d'erreur JavaScript pour accéder au numéro de ligne de l'appelant.

Détermination de l'URL source de l'appelant :

Malheureusement, ce n'est pas le cas Il est simple d'obtenir l'URL source directement à partir de la fonction de l'appelant. Cependant, vous pouvez utiliser un bundler tel que Webpack avec des cartes sources pour générer un mappage entre le code fourni et les fichiers source, vous permettant ainsi de mapper le numéro de ligne de l'appelant à son emplacement source d'origine. .

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn