JavaScript - 获取调用函数的名称

标签 javascript

是否可以在这段代码中获取字符串“markHotel”?

this.markHotel = this.markPrice = function() {

    // get "markHotel"

};

this.markHotel();

最佳答案

您可以使用 Function.prototype.bind()。这是一个简单的例子:

function base() {
  console.log(this.name);

  // do some other stuff using this.name or other this props...
}

var markPrice = base.bind({ name: 'markPrice' });

var markHotel = base.bind({ name: 'markHotel' });

// this will log 'markPrice'
markPrice();

// this will log 'markHotel'
markHotel();

看起来您可能在类构造函数中执行此操作,但从您的示例中并不完全清楚。如果是这种情况,请确保不要混淆类构造函数的“this”上下文和“base”函数的“this”上下文,后者是在设置 markPrice 和 markHotel 时手动绑定(bind)的。

绑定(bind)文档:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/bind

这是一支笔:http://codepen.io/bsidelinger912/pen/QKLvzL

关于JavaScript - 获取调用函数的名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39232604/

相关文章:

javascript - Twitter 支持 OAuth2 授权代码流程吗?

javascript - 从数组中检索均匀分布的元素数量

php - 两个数组的 Google 散点图

javascript - 我如何从 ListView 中包含(或扩展)Odoo 核心功能(例如 Instance.web.ListView.extend)

javascript - iPad JavaScript 计时器停止运行检测到 sleep 模式

javascript - 使用拖动事件在 Angular Material 垫表中进行行重新排序

javascript - 我想在我的vue.js应用中播放WAV文件

javascript - 我在 babel 中使用 Symbol.isConcatSpread 有问题吗?

javascript - Google map + OverlappingMarkerSpiderfier 自定义标记不起作用

javascript - 使用 jquery 计算 textarea 中的链接数