【问题标题】:Spinner is not quite displaying correct number if spinner is blank如果微调器为空白,微调器不会完全显示正确的数字
【发布时间】:2011-11-21 10:23:48
【问题描述】:

我有 5 个几乎可以完美运行的微调器,只有一个小故障我无法克服。

假设发生的情况是,如果微调器为空白,则无论该微调器中的前一个数字是什么,它都会显示该前一个数字。

它所做的是在 5 个微调器中的任何一个中输入任何先前的数字,它会在空白微调器中显示该数字。

那么,如果微调器为空白,我该如何获取它以显示该微调器的前一个数字,而不是显示从空白微调器中的任何微调器输入的最后一个前一个数字?

以下是我的微调器代码:

     function Spinner(elem,min, max){
 this.elem = elem;
 this.elem.value = min;
 this.min = min;
 this.max = max;
 this.timer;
 this.speed = 150; //milliseconds between scroll values
 var selfO = this;

 this.elem.onkeyup = function(){
    var regex = /^[0-9]*$/;
    if(!regex.test(selfO.elem.value)){
    selfO.elem.value = selfO.elem.value.substring(0,selfO.elem.value.length-1);
                            return;
                        }
                        selfO.validateValue();
                    }

      this.validateValue = function(){
      if(Number(selfO.elem.value) > selfO.max) {selfO.elem.value = selfO.max;}
      if(Number(selfO.elem.value) < selfO.min) {selfO.elem.value = selfO.min;}
                    }

                    this.stopSpinning = function(){
                        clearTimeout(selfO.timer);
                    }

                    this.spinValue = function(dir){
                        selfO.elem.value = Number(selfO.elem.value) + dir;
                        selfO.validateValue();
                        selfO.timer = setTimeout(function(){selfO.spinValue(dir);},selfO.speed);
                    }

                };

           window.onload=function(){
                        //create the Spinner objects
                        var SpinnerHours = new Spinner(document.getElementById('txtHours'),0,23);                
                        var SpinnerMins = new Spinner(document.getElementById('txtMins'),0,59);
                        var SpinnerSecs = new Spinner(document.getElementById('txtSecs'),0,59);
                        var SpinnerWeight = new Spinner(document.getElementById('txtWeight'),0,100);
                        var SpinnerQuestion = new Spinner(document.getElementById('txtQuestion'),0,100);

                        document.getElementById('txtHours').onblur = function(){ this.value = cleanSpin(this.value);}
                        document.getElementById('txtMins').onblur = function(){ this.value = cleanSpin(this.value);}
                        document.getElementById('txtSecs').onblur = function(){ this.value = cleanSpin(this.value);}
                        document.getElementById('txtWeight').onblur = function(){ this.value = cleanSpin(this.value);}
                        document.getElementById('txtQuestion').onblur = function(){ this.value = cleanSpin(this.value);}

            function cleanSpin(obj) {
                if(obj > 0) {
                    var str = obj.replace(/^0*/,'');
                    lastSpin = str;
                    return str;
                }
                else {
                    return lastSpin;
                }
            }

            var lastSpin = 1;

【问题讨论】:

  • Spinner 类从何而来?它不是标准的 Javascript AFAIK。
  • 我猜测它来自 jQuery UI,但我很好奇这条线的作用。 cleanSpin(this.value);
  • 我不想用代码重载,但如果你想要微调器类,那么我现在已将其包含在问题中并验证值。我认为问题出在我的 cleanSpin() 函数中

标签: javascript function spinner


【解决方案1】:

问题在于您的 lastSpin 变量,实际上是您的 cleanSpin() 函数,都在全局范围内,因此在所有 Spinner 实例之间共享。

相反,您应该尝试将cleanSpin 方法或其变体添加到Spinner“类”,使其成为该 Spinner 实例的本地方法。

编辑:这是完整的 Javascript 来说明我的意思。我根本没有对此进行测试,因为我没有执行此操作所需的其余代码,但希望您能看到我所做的更改:

function Spinner(elem, min, max) {
    this.elem = elem;
    this.elem.value = min;
    this.min = min;
    this.max = max;
    this.timer;
    this.speed = 150; //milliseconds between scroll values
    this.lastSpin = 1; // added lastSpin as a property of the Spinner
    var selfO = this;

    this.elem.onkeyup = function() {
        var regex = /^[0-9]*$/;
        if (!regex.test(selfO.elem.value)) {
            selfO.elem.value = selfO.elem.value.substring(0, selfO.elem.value.length - 1);
            return;
        }
        selfO.validateValue();
    }

    // I have added the onblur function inside the Spinner "class"
    this.elem.onblur = function() {
        if (self0.elem.value > 0) {
            var str = self0.elem.value.replace(/^0*/, '');
            self0.lastSpin = str;
            self0.elem.value = str;
        }
        else {
            self0.elem.value = lastSpin;
        }
    };

    this.validateValue = function() {
        if (Number(selfO.elem.value) > selfO.max) {
            selfO.elem.value = selfO.max;
        }
        if (Number(selfO.elem.value) < selfO.min) {
            selfO.elem.value = selfO.min;
        }
    };

    this.stopSpinning = function() {
        clearTimeout(selfO.timer);
    };

    this.spinValue = function(dir) {
        selfO.elem.value = Number(selfO.elem.value) + dir;
        selfO.validateValue();
        selfO.timer = setTimeout(function() {
            selfO.spinValue(dir);
        }, selfO.speed);
    };

};

window.onload = function() {
    //create the Spinner objects
    var SpinnerHours = new Spinner(document.getElementById('txtHours'), 0, 23);
    var SpinnerMins = new Spinner(document.getElementById('txtMins'), 0, 59);
    var SpinnerSecs = new Spinner(document.getElementById('txtSecs'), 0, 59);
    var SpinnerWeight = new Spinner(document.getElementById('txtWeight'), 0, 100);
    var SpinnerQuestion = new Spinner(document.getElementById('txtQuestion'), 0, 100);
}

【讨论】:

  • 我编辑了你的答案,这就是你的意思,例如:
  • 我明白你的意思。这段代码确实删除了微调器中数字前面的所有零,该数字之前确实有效,但如果微调器为空白并且我点击离开,它就不会在微调器中显示任何内容。我会检查一下。如果你再看看这个,你能看看你的代码,看看为什么,我会看看我的文档,看看我能不能弄明白:)
  • 我认为 this.lastSpin = 1 是错误,但我仍在努力解决
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-03-09
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多