2013-01-05 52 views
1

我已經創建了一個自定義綁定來用作顏色選擇器。如何在自定義綁定中綁定css類

<ul data-bind="colorPicker: selcol"></ul> 

它創建10個內聯div,每個div代表其他顏色。當我點擊一個div時,顏色被選中。我在分配'selected'時遇到了問題。 css類到選定的div。我嘗試在自定義綁定中使用css綁定,但這不起作用。它只選擇初始div,即使在選擇其他div之後仍保持選中狀態。

請檢查例子:http://jsfiddle.net/zbkkzdsp/Jbvvq/

感謝您的幫助。如果您對我的代碼有任何提示或意見,請告訴我。我對淘汰賽頗有新意,並會藉此機會學習更多。

+0

我沒有看到在撥弄任何代碼,只是結果。任何想法是什麼? –

+1

Jsfiddle這些天很有趣。同時使用http://codepen.io/。 – jjperezaguinaga

+0

是的,即使是最簡單的小提琴,我也遇到了麻煩。結束使用jsbin.com –

回答

2

看起來你正在用自定義綁定中的計算值做很多花哨的東西,所以我會建議爲你的顏色創建視圖模型。

首先定義爲每個顏色的視圖模型:

var ColorModel = function(options) { 
    var self = this; 

    // Keep a reference to the parent picker for selection 
    self.picker = options.picker; 

    // The CSS value of the color 
    self.color = ko.observable(options.color || 'transparent'); 

    // A flag denoting whether this color is selected 
    self.selected = ko.observable(options.selected || false); 

    // This will be called when the corresponding color link is clicked 
    // Note that we're not doing any event binding with jQuery as with your custom binder 
    self.select = function() { 
    self.picker.selectColor(self); 
    }; 
}; 

然後在顏色選擇器本身就是一個視圖模型:

var ColorPickerModel = function() { 
    var self = this; 

    // The list of all colors 
    self.colors = ko.observableArray([]); 

    self.addColor = function(color) { 
    var newColor = new ColorModel({ 
     picker: self, 
     color: color 
    }); 

    self.colors.push(newColor); 
    return newColor; 
    }; 

    // Called by individual colors 
    self.selectColor = function(colorModel) { 
    // Deselect the current color so we don't select two 
    var current = self.selected(); 
    if (current) { 
     current.selected(false); 
    } 

    // Mark the color as selected - KO will do the rest 
    colorModel.selected(true); 

    // Remember this color as the selected one to deselect later 
    self.selected(colorModel); 
    }; 

    // Create at least one default color 
    var transparent = self.addColor('transparent'); 

    // Keep track of the selected color - set to transparent by default 
    self.selected = ko.observable(transparent); 
    transparent.select(); 
}; 

那麼你的HTML視圖綁定到你的選擇器視圖模式:

<div id="color-picker"> 
    <div data-bind="foreach: colors"> 
    <a href="#" data-bind=" 
     style: { 'background-color': $data.color }, 
     css: { 'selected': selected }, 
     click: select"></a> 
    </div> 
    <div> 
    Selected color: <span data-bind="text: selected().color"></span> 
    </div>  
</div> 

把它綁在一起:

var pickerDiv = document.getElementById('color-picker'), 
    picker = new ColorPickerModel(); 

// Add some colors 
picker.addColor('red'); 
picker.addColor('blue'); 
picker.addColor('green'); 
picker.addColor('orange'); 
picker.addColor('purple'); 
picker.addColor('black'); 

// Bind Knockout 
ko.applyBindings(picker, pickerDiv); 

// Add more colors - the view will update automatically 
picker.addColor('pink'); 

這裏有一個工作示例:http://jsbin.com/izarik/1/edit

+0

謝謝。您的解決方案非常好,但我的目標是儘可能多地進行自定義綁定以便以後重複使用。我想將許多這樣的顏色選擇器放置在不同的網站上,因此使用單個綁定處理程序很容易實現。 – Eori

+0

在這種情況下,如果您已經在自定義綁定內部使用jQuery事件來處理點擊,爲什麼不使用它來分配「選定」類?例如。在每次點擊時,addClass('selected')。也就是說,如果您已經沒有按照預期使用KO,那麼您爲什麼需要KO綁定呢? –

+1

我設法做的工作示例: – Eori