动态变量在javascript中命名

ign*_*aty 14 javascript variables dynamic

我有变量:

var variableDynamic = 1;
// or    
var variableDynamic = 1 + i++;
Run Code Online (Sandbox Code Playgroud)

有没有办法用它来创建动态变量名称,例如:

var variableName + variableDynamic = {};
// or
var (variableName + variableDynamic) = {};
Run Code Online (Sandbox Code Playgroud)

我知道我上面写的是荒谬的,但这是为了解释这个想法.可能吗?


好的,每次用户点击添加新文件组时我想要创建元素(上传表单),一切正常,除了我用它的插件需要特殊的变量,每个上传表单触发上传按钮(.uploadStoredFiles ()).

这是我做的粗略代码:

    $('#addOneMoreFileOrGroup').on('click', function(){

    var latestFileUploaderId = parseInt($('.well-large .file-uploader').last().attr('id').split('-')[2]) + 1;

    $('.well-large .control-group:last').after('<div class="control-group deal-type-online">  \
        <label class="control-label">File / File Group Title:</label> \
        <div class="controls"> \
            <input class="span4 file-title" type="text"> \
            <span class="question label label-warning" data-title="File / Group Name:" data-content="Name for your file or group of related files (for example your brand logotype in different file formats)." data-original-title="">?</span> \
            <div id="file-uploader-' + latestFileUploaderId + '" class="file-uploader"></div> \
        </div> \
    </div>');

    var HERE_I_NEED_DYNAMIC_VAR = new qq.FileUploader({
        element: document.getElementById('file-uploader-' + latestFileUploaderId + ''),
        action: 'do-nothing.htm',
        autoUpload: false,
        debug: true,
        uploadButtonText: '<i class="icon icon-plus"></i> Select Files...',
        onSubmit: function() {

            $('#file-uploader-' + latestFileUploaderId + ' .qq-uploader').after('<button id="file-uploader-trigger-' + latestFileUploaderId + '" class="btn btn-primary"><i class="icon-upload icon-white"></i> Upload now</button>');

            $('#file-uploader-trigger-' + latestFileUploaderId + '').on('click', function() {

                if($(this).parent().parent().parent().parent().find('.file-title').val() !== '') {
                    HERE_I_NEED_DYNAMIC_VAR.uploadStoredFiles();
                } else {

                    $(this).parent().parent().parent().addClass('error');

                }

            });

        }
    });

});

}
Run Code Online (Sandbox Code Playgroud)

Con*_*ell 29

在JavaScript中,对象的属性可以通过obj.prop或访问obj['prop'].

在全局范围内,所有变量都是window属性的子项.所以你将能够做到:

var variableDynamic = 'Test';
window['variableName' + variableDynamic] = 'your value';
Run Code Online (Sandbox Code Playgroud)

看看这个小提琴.

但是,如果您想将此变量的范围限制为函数,则必须定义父对象并使用它来代替window.


sai*_*iuc 16

您可以使用创建动态变量eval.

eval("dynamic" + i + " = val[i]");
Run Code Online (Sandbox Code Playgroud)

另请看一下:在JavaScript中使用动态变量名称


Awe*_*s01 5

要添加到 FAngels 答案中,您可以在任何地方使用括号表示法。这意味着除了使用之外window['var'],您还可以使用this['var'].


Tho*_*sen 4

为此,您可以使用eval(). 却eval()是邪恶的。对于这样的事情,您应该使用数组。

例子:

var i = 1337;
eval('var myvar' + i + ' = \'value\';');

alert(myvar1337);
Run Code Online (Sandbox Code Playgroud)