簡體   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