Проблема с ehynds jquery-multiselect
У меня есть скрипка, показывающая эту проблему здесь: http://jsfiddle.net/jrwarwick/XEg4K/
Пожалуйста, не обращайте внимания: а) меню изначально не скрывается и не отображается в неправильном месте, что не имеет отношения к делу. б) мультиселект не работает на этой скрипке по неизвестной причине.
ВОПРОС: Когда компонент многократного выбора повторяется таким образом, я получаю проблему. Если вы щелкнете по флажку / переключателю в нижней части мультиселектора, он будет работать как положено. НО, если вы щелкнете метку вместо флажка / радио, тогда первый мультиселектор получит событие вместо того, которое было открыто, и первый мультиселектор перезапишет свое значение соответствующим индексированным значением фактической выбранной опции мультиселекции!
Возможен ли для этого обходной путь? Или я должен пойти и поместить это в баг-трекер Эрика Хиндса?
Благодарю.
КОД:
<div class="form-horizontal" style="position: relative">
<div class="control-group">
<h4 style="margin-left: 10px;">Characteristics</h4>
<div id="characterisitics" data-bind="with: d">
<div data-bind="foreach: Rows" class="control-group">
<label class="control-label" data-bind="text: name"></label>
<div class="controls">
<label class="label" for="ddlContent" style="min-width: 60px; text-align: right" data-bind="text: typename"></label>
<select id="ddlContent" class="input-medium" data-bind="multiSelectCheck:true, minWidth: 150, multiple: typename=='List', selectedOptions: values, header: false, options: TypeContent, optionsText: 'name', optionsValue: 'cvalue'" multiple="multiple">
</select>
<input type="text" class="input-large" maxlength="50" data-bind="value: $parent['type' + location]" />
</div>
</div>
</div>
</div>
</div>
<script type="text/javascript">
ko.utils.unwrapObservable(allBindingsAccessor().multiselectOptions) || {};
// pass the original options to the similar widget option
if (ko.utils.unwrapObservable(allBindingsAccessor().optionsCaption)) {
multiselectOptions.noneSelectedText = ko.utils.unwrapObservable(allBindingsAccessor().optionsCaption);
}
if (ko.utils.unwrapObservable(allBindingsAccessor().header) === false) {
multiselectOptions.header = false;
}
multiselectOptions.multiple = ko.utils.unwrapObservable(allBindingsAccessor().multiple);
multiselectOptions.minWidth = ko.utils.unwrapObservable(allBindingsAccessor().minWidth);
allBindingsAccessor().optionsCaption = '';
$(element).multiselect(multiselectOptions);
ko.utils.domNodeDisposal.addDisposeCallback(element, function () {
$(element).multiselect("destroy");
});
},
update: function (element, valueAccessor, allBindingsAccessor, viewModel, bindingContext) {
// This will be called once when the binding is first applied to an element,
// and again whenever the associated observable changes value.
// Update the DOM element based on the supplied values here.
var multiselectOptions = ko.utils.unwrapObservable(allBindingsAccessor().multiSelectCheck);
// remove this and use the widget's
// pass the original options to the similar widget option
allBindingsAccessor().optionsCaption = '';
ko.bindingHandlers.options.update(element, valueAccessor, allBindingsAccessor, viewModel, bindingContext);
setTimeout(function () {
$(element).multiselect("refresh");
}, 0);
}
};
var data = { "d": {
"type1": ko.observable(),
"type2": ko.observable(),
"type3": ko.observable(),
"Rows": [
{
"id": 26,
"catid": 24,
"name": "Processor Type",
"location": 1,
"type": 1,
"typename": "Text",
"TypeContent": [
{
"id": 195,
"name": "Celeron",
"cvalue": "Celeron",
"location": 7,
"name_fixed": "celeron laptops",
"typeid": 26
},
{
"id": 196,
"name": "Athlon",
"cvalue": "Athlon",
"location": 8,
"name_fixed": "athlon laptops",
"typeid": 26
},
{
"id": 599,
"name": "Centrino",
"cvalue": "Centrino",
"location": 9,
"name_fixed": "centrino laptops",
"typeid": 26
},
{
"id": 772,
"name": "PowerPC G4",
"cvalue": "PowerPC G4",
"location": 10,
"name_fixed": "powerpc g4 laptops",
"typeid": 26
},
{
"id": 969,
"name": "Sempron",
"cvalue": "Sempron",
"location": 11,
"name_fixed": "sempron laptops",
"typeid": 26
},
{
"id": 970,
"name": "Turion 64",
"cvalue": "Turion 64",
"location": 12,
"name_fixed": "turion 64 laptops",
"typeid": 26
},
{
"id": 2714,
"name": "Intel Dual Core",
"cvalue": "Intel Dual Core",
"location": 13,
"name_fixed": "intel dual core laptops",
"typeid": 26
},
{
"id": 3472,
"name": "Intel Core Duo",
"cvalue": "Intel Core Duo",
"location": 14,
"name_fixed": "intel core duo laptops",
"typeid": 26
},
{
"id": 3710,
"name": "C7 M",
"cvalue": "C7 M",
"location": 15,
"name_fixed": "c7 m laptops",
"typeid": 26
},
{
"id": 3821,
"name": "Intel Core 2 Duo",
"cvalue": "Intel Core 2 Duo",
"location": 16,
"name_fixed": "intel core 2 duo laptops",
"typeid": 26
},
{
"id": 3822,
"name": "Intel Quad Core",
"cvalue": "Intel Quad Core",
"location": 17,
"name_fixed": "intel quad core laptops",
"typeid": 26
},
{
"id": 3823,
"name": "Intel Core 2 Quad",
"cvalue": "Intel Core 2 Quad",
"location": 19,
"name_fixed": "intel core 2 quad laptops",
"typeid": 26
},
{
"id": 4172,
"name": "Intel Atom",
"cvalue": "Intel Atom",
"location": 20,
"name_fixed": "intel atom laptops",
"typeid": 26
},
{
"id": 5718,
"name": "Intel Core i5",
"cvalue": "Intel Core i5",
"location": 20,
"name_fixed": "intel core i5 laptops",
"typeid": 26
},
{
"id": 5719,
"name": "Intel Core i7",
"cvalue": "Intel Core i7",
"location": 20,
"name_fixed": "intel core i7 laptops",
"typeid": 26
},
{
"id": 5822,
"name": "Intel Core i3",
"cvalue": "Intel Core i3",
"location": 20,
"name_fixed": "intel core i3 laptops",
"typeid": 26
},
{
"id": 5885,
"name": "Intel Pentium",
"cvalue": "Intel Pentium",
"location": 20,
"name_fixed": "intel pentium laptops",
"typeid": 26
},
{
"id": 5924,
"name": "AMD Phenom",
"cvalue": "AMD Phenom",
"location": 20,
"name_fixed": "amd phenom laptops",
"typeid": 26
},
{
"id": 5933,
"name": "Intel Core Solo",
"cvalue": "Intel Core Solo",
"location": 20,
"name_fixed": "intel core solo laptops",
"typeid": 26
},
{
"id": 5934,
"name": "Dual Core II",
"cvalue": "Dual Core II",
"location": 20,
"name_fixed": "dual core ii laptops",
"typeid": 26
},
{
"id": 5942,
"name": "AMD V Series",
"cvalue": "AMD V Series",
"location": 20,
"name_fixed": "amd v series laptops",
"typeid": 26
},
{
"id": 5943,
"name": "Athlon II Neo",
"cvalue": "Athlon II Neo",
"location": 20,
"name_fixed": "athlon ii neo laptops",
"typeid": 26
},
{
"id": 5967,
"name": "Celeron 900",
"cvalue": "Celeron 900",
"location": 20,
"name_fixed": "celeron 900 laptops",
"typeid": 26
},
{
"id": 6018,
"name": "Atom Dual Core",
"cvalue": "Atom Dual Core",
"location": 20,
"name_fixed": "atom dual core laptops",
"typeid": 26
},
{
"id": 6059,
"name": "AMD E350",
"cvalue": "AMD E350",
"location": 20,
"name_fixed": "amd e350 laptops",
"typeid": 26
},
{
"id": 6161,
"name": "AMD P340",
"cvalue": "AMD P340",
"location": 20,
"name_fixed": "amd p340 laptops",
"typeid": 26
},
{
"id": 6567,
"name": "AMD C50",
"cvalue": "AMD C50",
"location": 20,
"name_fixed": "amd c50 laptops",
"typeid": 26
},
{
"id": 6589,
"name": "AMD Turion",
"cvalue": "AMD Turion",
"location": 20,
"name_fixed": "amd turion laptops",
"typeid": 26
},
{
"id": 6605,
"name": "AMD Dual-Core",
"cvalue": "AMD Dual-Core",
"location": 20,
"name_fixed": "amd dual core laptops",
"typeid": 26
},
{
"id": 6827,
"name": "AMD E-450",
"cvalue": "AMD E-450",
"location": 20,
"name_fixed": "amd e 450 laptops",
"typeid": 26
},
{
"id": 6828,
"name": "AMD A-Series",
"cvalue": "AMD A-Series",
"location": 20,
"name_fixed": "amd a series laptops",
"typeid": 26
},
{
"id": 6829,
"name": "AMD E-240",
"cvalue": "AMD E-240",
"location": 20,
"name_fixed": "amd e 240 laptops",
"typeid": 26
},
{
"id": 6903,
"name": "AMD E2",
"cvalue": "AMD E2",
"location": 20,
"name_fixed": "amd e2 laptops",
"typeid": 26
},
{
"id": 6905,
"name": "AMD C-Series",
"cvalue": "AMD C-Series",
"location": 20,
"name_fixed": "amd c series laptops",
"typeid": 26
},
{
"id": 6906,
"name": "AMD E-Series",
"cvalue": "AMD E-Series",
"location": 20,
"name_fixed": "amd e series laptops",
"typeid": 26
}
]
},
{
"id": 493,
"catid": 24,
"name": "Weight",
"location": 2,
"type": 2,
"typename": "Range",
"TypeContent": [
{
"id": 4755,
"name": "1-2 kg",
"cvalue": "1-2",
"location": 1,
"name_fixed": "1 2 kg laptops",
"typeid": 493
},
{
"id": 4756,
"name": "2-3 kg",
"cvalue": "2-3",
"location": 2,
"name_fixed": "2 3 kg laptops",
"typeid": 493
},
{
"id": 4757,
"name": "3-4 kg",
"cvalue": "3-4",
"location": 3,
"name_fixed": "3 4 kg laptops",
"typeid": 493
},
{
"id": 4758,
"name": "4-5 kg",
"cvalue": "4-5",
"location": 4,
"name_fixed": "4 5 kg laptops",
"typeid": 493
}
]
},
{
"id": 704,
"catid": 24,
"name": "Display Resolution",
"location": 3,
"type": 3,
"typename": "List",
"TypeContent": [
{
"id": 6982,
"name": "2880x1800",
"cvalue": "2880x1800",
"location": 1,
"name_fixed": "2880x1800 laptops",
"typeid": 704
},
{
"id": 6981,
"name": "2560x1600",
"cvalue": "2560x1600",
"location": 2,
"name_fixed": "2560x1600 laptops",
"typeid": 704
},
{
"id": 6973,
"name": "1920x1080",
"cvalue": "1920x1080",
"location": 2,
"name_fixed": "1920x1080 laptops",
"typeid": 704
},
{
"id": 6974,
"name": "1680x1080",
"cvalue": "1680x1080",
"location": 2,
"name_fixed": "1680x1080 laptops",
"typeid": 704
},
{
"id": 6975,
"name": "1600x900",
"cvalue": "1600x900",
"location": 3,
"name_fixed": "1600x900 laptops",
"typeid": 704
},
{
"id": 6976,
"name": "1440x900",
"cvalue": "1440x900",
"location": 4,
"name_fixed": "1440x900 laptops",
"typeid": 704
},
{
"id": 6977,
"name": "1366x768",
"cvalue": "1366x768",
"location": 5,
"name_fixed": "1366x768 laptops",
"typeid": 704
},
{
"id": 6978,
"name": "1280x1024",
"cvalue": "1280x1024",
"location": 6,
"name_fixed": "1280x1024 laptops",
"typeid": 704
},
{
"id": 6979,
"name": "1280x800",
"cvalue": "1280x800",
"location": 7,
"name_fixed": "1280x800 laptops",
"typeid": 704
},
{
"id": 6980,
"name": "1280x720",
"cvalue": "1280x720",
"location": 8,
"name_fixed": "1280x720 laptops",
"typeid": 704
},
{
"id": 6986,
"name": "1024x600",
"cvalue": "1024x600",
"location": 9,
"name_fixed": "1024x600 laptops",
"typeid": 704
}
]
}
]
}
};
ko.utils.arrayForEach(data.d.Rows, function (o, i) {
o.values = ko.observableArray((data.d['type' + o.location]() + '').replace(', ', ',').split(','));
o.values.subscribe(function () { data.d['type' + this.location](this.values().join(',')) }, o);
});
ko.applyBindings(data);
</script>
1 ответ
Теперь я осознаю проблему.
Каждое поле выбора нуждалось в уникальном идентификаторе.
С этим разобрались.