繁体   English   中英

jQuery each()函数的范围?

[英]Scope of jQuery each() function?

我正在使用jQuery ColorPicker小部件-特别是行使ColorPickerSetColor函数(内部只是'setColor')。 代码摘录:

        setColor: function(col) {
            if (typeof col == 'string') {
                col = HexToHSB(col);
            } else if (col.r != undefined && col.g != undefined && col.b != undefined) {
                col = RGBToHSB(col);
            } else if (col.h != undefined && col.s != undefined && col.b != undefined) {
                col = fixHSB(col);
            } else {
                return this;
            }
            return this.each(function(){
                if ($(this).data('colorpickerId')) {
                    var cal = $('#' + $(this).data('colorpickerId'));
                    cal.data('colorpicker').color = col;
                    cal.data('colorpicker').origColor = col;
                    fillRGBFields(col, cal.get(0));
                    fillHSBFields(col, cal.get(0));
                    fillHexFields(col, cal.get(0));
                    setHue(col, cal.get(0));
                    setSelector(col, cal.get(0));
                    setCurrentColor(col, cal.get(0));
                    setNewColor(col, cal.get(0));
                }
            });
        }

似乎小部件中有错误。 当在each()调用中检查'col'参数时,它是未定义的。 我已经阅读了文档和其他示例,并且我能找到的所有内容都表明,当eacher()调用执行函数时,“ col”仍应在范围内,但似乎不是...

救命?

谢谢!

尝试定义另一个变量:

 setColor: function(xCol) {
     var col = xCol;
     // ...
 }

如果这行得通,那么在函数参数方面,闭包系统就会有些奇怪。 这种行为可能是特定于浏览器的。

我刚结束使用一个已知范围内的临时变量(setColor函数的父级)。 绝对是hack,但它可以工作。 如果有人知道如何正确解决此问题,请告诉我。 :)

谢谢! -丰富

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM