1

所以我有一个函数可以显示来自 CSS 类的随机数图像。问题是当我运行应用程序两次时,第二个应用程序会更改第一个应用程序上的图像,而随机数不会出现在第二个应用程序中。我认为这可能是因为我没有局部变量,但是无论有没有全局变量,我都会遇到同样的问题。我可以使用 iframe,但必须有一段距离才能让它工作 Js Only 吗?

我创建了一个显示问题的 jsFiddle,只需按两次运行按钮并玩骰子,您就会看到我的问题。 http://jsfiddle.net/dymond/gUL9U/

以及创建类的函数。

function dicesides_func(nr){
    // go to dice-window-wrapper again
    // this could be put in a seporate functon
    var elementToAddDice=" dice-window-wrapper ",
    obj=this, // using this here that's why it's called wiht
    dice,i=0,total=0; // all the dice in this dice window
    // dicesides_func.call to set the right this context
    if(nr)
    {
        while((" "+obj.className+" ").indexOf(elementToAddDice)==-1){
            obj=obj.parentNode;
        }
        obj=obj.getElementsByTagName("ul")[2];
        var dicessides = createElementWithClass('li',nr);
        obj.appendChild(dicessides);
        // calculate total (can do in a seporate function)

        dice = obj.getElementsByTagName("li");
    }
    else
    {
        dice = document.getElementsByClassName("dice");   
    }
    for(i=0;i<dice.length;i++){
        total=total+getNumberForClass(dice[i].className);
    }
    //alert(total);

    var wrapper = document.getElementsByClassName("dice-toolbar-counter-wrapper")[0];

    while (wrapper.hasChildNodes()) {
        wrapper.removeChild(wrapper.lastChild);
    }

    var ttl = total.toString();
    var arr = [];
    for (var i = 0;i<ttl.length;i++) {
        var digit = ttl[i];
        var newelem = createElementWithClass('li',"side-" + ttl[i]);
        //alert(dice_toolbar_counter_wrapper_Li)
        wrapper.appendChild(newelem);
    } 

}
4

0 回答 0