Я пытаюсь создать привязки knockoutjs для диалогов jquery ui и не могу открыть диалоговое окно. Элемент диалога создается правильно, но, похоже, имеет display: none
, что вызов dialog('open')
не удаляется. Кроме того, вызов dialog('isOpen')
возвращает объект диалога, а не логический.
Я использую последние knockoutjs и jquery 1.4.4 с jquery ui 1.8.7. Я также пробовал его с помощью jQuery 1.7.1 с теми же результатами. Здесь мой HTML:
<h1 class="header" data-bind="text: label"></h1>
<div id="dialog" data-bind="dialog: {autoOpen: false, title: 'Dialog test'}">foo dialog</div>
<div>
<button id="openbutton" data-bind="dialogcmd: {id: 'dialog'}" >Open</button>
<button id="openbutton" data-bind="dialogcmd: {id: 'dialog', cmd: 'close'}" >Close</button>
</div>
и это javascript:
var jQueryWidget = function(element, valueAccessor, name, constructor) {
var options = ko.utils.unwrapObservable(valueAccessor());
var $element = $(element);
var $widget = $element.data(name) || constructor($element, options);
$element.data(name, $widget);
};
ko.bindingHandlers.dialog = {
init: function(element, valueAccessor, allBindingsAccessor, viewModel) {
jQueryWidget(element, valueAccessor, 'dialog', function($element, options) {
console.log("Creating dialog on " + $element);
return $element.dialog(options);
});
}
};
ko.bindingHandlers.dialogcmd = {
init: function(element, valueAccessor, allBindingsAccessor, viewModel) {
$(element).button().click(function() {
var options = ko.utils.unwrapObservable(valueAccessor());
var $dialog = $('#' + options.id).data('dialog');
var isOpen = $dialog.dialog('isOpen');
console.log("Before command dialog is open: " + isOpen);
$dialog.dialog(options.cmd || 'open');
return false;
});
}
};
var viewModel = {
label: ko.observable('dialog test')
};
ko.applyBindings(viewModel);
Я установил JSFiddle, который воспроизводит проблему.
Мне интересно, имеет ли это отношение к knockoutjs и обработке событий. Я попытался вернуть true
из обработчика кликов, но это не повлияло ни на что.