javascript - dynamic variables

萝らか妹 提交于 2019-12-17 10:03:32

问题


Hi I am trying to make dynamic variables but it is saying `variable v0 (through to v5) is not defined.

td.each(function(i){
eval('var v' + i + ' = \'' + $(this).html() + '\';' );
});

any help would be muchly appreciated.


回答1:


That sounds like a bad idea.

Is there any reason you can't do this?

var tdHtml = td.map(function() { return $(this).html(); }).get();



回答2:


Oh my.

If you want to create a global "dynamic variable" you should not use var. In this context it creates a variable that is local inside of the each-function, which is quite useless (and will cause it to be undefined outside of the loop, which is what you're experiencing). Instead you should do it like this:

td.each(function(i){
  window['v' + i] = $(this).html();
});

The downside with the above code is that global variables are not really great either.

On the other hand, if you want a local variable (if for example there will be more code in the loop that uses this varaible, then I would do it like this:

td.each(function(i){
  var dynVars = {};
  dynVars['v' + i] = $(this).html();

  alert(dynVars.v4); // use the dynamic variables by saying "dynVars.NAME"

});

You could combine these two solutions, by putting the declaration of dynvars (var dynVars = {}) in the scope where you want to be able to access your variables instead. As long as it is also visible in this each-callback, everything will work out fine.



来源:https://stackoverflow.com/questions/4385084/javascript-dynamic-variables

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!