[英]Get the name of variable function was assigned to
我正在尝试返回分配函数的变量的名称。
我在下面列举了一个例子。 最终结果是我希望modelPerson.title()
返回变量名称title
。
例如,我有以下代码:
定义一些基本模型类型
var types = {
string: function() {
return function() {
return "I want this to return 'title'";
}
}
};
使用模型类型
var modelPerson = {
title: types.string(),
firstName: types.string(),
surname: types.string(),
position: types.string()
};
试图返回标题
console.log(modelPerson.title());
对不起,如果这有点不清楚。 我有一个JSFiddle,如果它有帮助: http : //jsfiddle.net/4f6VE/
谢谢你提供的所有帮助
这实际上是可能的,但涉及一些v8特定的东西:
var types = {
string: function() {
return function() {
var obj = {};
var prepare = Error.prepareStackTrace;
Error.prepareStackTrace = function (_, stack) {
return stack
}
Error.captureStackTrace(obj)
var method = obj.stack[0].getMethodName();
Error.prepareStackTrace = prepare;
return method;
}
}
};
var modelPerson = {
title: types.string(),
firstName: types.string(),
surname: types.string(),
position: types.string()
};
console.log(modelPerson.title());
console.log(modelPerson.firstName());
但你可能应该使用一些不那么疯狂的东西
我真的不知道这是为了什么,但是
var modelPerson = {
title : function title(){ return arguments.callee.name; },
firstName : function firstName(){ return arguments.callee.name; },
surname : function surname(){ return arguments.callee.name; },
position : function position(){ return arguments.callee.name; },
}
应该做你说的。
编辑
Banzaaai~!
var types = {
string: function(){
eval('var x = function '+arguments.callee.caller.name+'(){var x = function(){return arguments.callee.caller.name;}; return x();}');
return x();
}
};
var modelPerson = {
title: function title(){ return types.string(); },
firstName: function firstName(){ return types.string(); },
surname: function surname(){ return types.string(); },
position: function position(){ return types.string(); }
};
很幸运的
var types = {
string: function(x){
return function(){ return x; }
}
};
var modelPerson = {
title: types.string('title'),
firstName: types.string('firstName'),
surname: types.string('surname'),
position: types.string('position')
};
我正在尝试返回分配函数的变量的名称
你不能,不可靠。 多个变量或属性可以引用同一个对象,并且某些对象不会被分配给变量(例如没有立即调用的名称的函数表达式)。
最终结果是我希望modelPerson.title()返回变量名称标题。
然后使用这样的东西:
function define(obj, name) {
obj[name] = function() {
return name;
};
}
var modelPerson = {};
define(modelPerson, "title");
define(modelPerson, "firstName");
define(modelPerson, "surname");
define(modelPerson, "position");
// … - a loop maybe?
> console.log(modelPerson.title());
"title"
这是一个可以在严格模式下工作的方法(没有弃用的arguments.callee或专有的arguments.callee.caller属性),使用您的代码进行最少的重新分解并且没有硬编码的名称:
var types={
string: function types(){
return function me() {
for(var it in this){
if(me==this[it]) return it;
}
};
}
};
var modelPerson = {
title: types.string(),
firstName: types.string(),
surname: types.string(),
position: types.string()
};
alert( modelPerson.title() ); // shows: "title"
alert( modelPerson.surname() ); // shows: "surname"
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.