我希望能够使用函数创建变量,类似于:
function createVar(a,b){
var [a]name[b];
}
如果我调用函数createVar(prefix,suffix)
,我将得到一个名为prefixnamesuffix
的变量。
我希望能够使用函数创建变量,类似于:
function createVar(a,b){
var [a]name[b];
}
如果我调用函数createVar(prefix,suffix)
,我将得到一个名为prefixnamesuffix
的变量。
function createVar(obj, a, b)
{
obj[a+'name'+b] = foo;
}
window[a+'name'+b]
。 - jackwandersfunction createVar(a, b, value) {
// declare the variable on current context(default is window),
// and set value, default is undefined
this[a + 'name' + b] = value;
}
用作:
createVar('a', 'b');
// variable anameb now is declare, but it's value is undefined
console.log(anameb); // -> undefined
createVar('prefix', 'suffix', 'optional');
// variable prefixnamesuffix now is exist in window
console.log(prefixnamesuffix); // -> 'optional'
或者:
var obj = {};
createVar.call(obj, 'pre', 'suf', 'defValue');
// variable prenamesuf is now exist in obj, but not exist in window
console.log(obj.prenamesuf); // -> 'defValue'
console.log(prenamesuf); // ReferenceError: prenamesuf is not defined
这是可能的 - 但有点棘手。
这一切都始于理解变量的作用域。让我们看一个基本的简单例子:
var myvar = 'I see';
这将创建一个变量,在基本层面上命名为myvar
,您可以访问它,例如alert(myvar);
,在这种情况下会警报"I see"。
实际上,这将在window对象上创建一个属性。因此,var myvar = 'I see';
与window['myvar'] = 'I see';
相同。
也可以使用这种方式创建复杂的对象。
一些更多的例子:
window['fred'] = 'howdy fred';// create fred property
var regularfred = 'howdy fred'; // create regularfred property
window['town'] = {}; // create town object
window['town']['george'] = 'georgetown'; //create town.george property
alert(fred + ":" + regularfred); // alerts "howdy fred:howdy fred"
alert(fred == regularfred);// alerts true
alert(this['town']['george']);// alerts "georgetown"
function createvar(a, b) {
this[a + 'name' + b] = "fredling";
alert(this[a + 'name' + b]);// alerts "fredling"
alert(window[a + 'name' + b]);// alerts "fredling"
}
var hi = 'hi';
var lo = 'loook';
createvar(hi, lo);
alert(this[hi + 'name' + lo]);// alerts "fredling"
关于此的工作示例要求:http://jsfiddle.net/pGWZN/