如何替换" a" in $ a with Variable

时间:2017-12-18 01:38:04

标签: javascript jquery variables dollar-sign

我试图更换字母" a"在函数中使用变量。例如,更改此:

setInterval(function(){         
    var $a = $( '.a' ); 
});

到此:

var thisClass = 'a';
setInterval(function(){         
    var $(thisClass) = $( '.'+thisClass );  
});

问题是= $( '.'+thisClass );工作正常,但var $(thisClass)没有。我尝试了一些变体,包括:var $thisClassvar $('thisClass'),但都没有效果。

是否可以插入/注入变量来代替" a"在$a

更新:

以下是我实际代码的当前状态。我确实意识到我可以简单地用$a替换$( '.a' ),这解决了我尝试使用var一次替换我函数中使用的所有classNames的一些问题。但是,如果我使用例如getElementById("a")getElementById("classVar"),我仍然会留下getElementById(classVar),但最终无法使用 setTimeout(function(){ var classVar = 'a'; $('.'+classVar).makisu( 'toggle' ); $('.'+classVar).makisu({ selector: 'dd', overlap: Math.random() * (.7 - .2) + .2, speed: Math.random() * (3 - .2) + .2 }); }, document.getElementById("a").childElementCount*universalBoxTime );

b2 = book{100,"c++ by saurabh",105.2};

2 个答案:

答案 0 :(得分:1)

只要您知道父对象,就可以通过属性名称访问它。

在您的情况下,您的变量看起来像是在全局范围内,因此您可以尝试从window对象访问它:

var thisClass = 'a';
setInterval(function(){         
    window['$' + thisClass] = $( '.'+thisClass );  
});

如果您在setInterval功能中只需要此变量,则可以使用this代替window

var thisClass = 'a';
setInterval(function(){         
    this['$' + thisClass] = $( '.'+thisClass );  
});

答案 1 :(得分:1)

你的问题在于范围。在您发布的代码中,classVar仅存在于setTimeout回调内部,无法在外部使用。在JavaScript中,您可以创建创建和调用其他函数的函数,这样您就可以通过这种方式使代码更通用:

function do_the_thing($elements) {
    var delay = $elements.children().length * universalBoxTime;

    setTimeout(function() {
        $elements.makisu('toggle');
        $elements.makisu({ 
            selector: 'dd',
            overlap: Math.random() * (.7 - .2) + .2,
            speed: Math.random() * (3 - .2) + .2
        });
    }, delay);
}

do_the_thing($('.a'));
do_the_thing($('.b'));

我使用$elements代替elements只是为了明确$elements是一个jQuery对象。当用作变量名称的一部分时,美元符号没有意义。