我有一个模态,在我的模态上我有一定的控制权和 3 个单选按钮。我希望用户能够选择/取消选择单选按钮,或者我希望用户只选择 1 个单选按钮。我正在使用 knockoutjs 将数据绑定到我的模态。
模态:
<div id="ModalGroup" class="modal hide fade" data-bind="with: Data" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h3 id="myModalLabel">Add Group</h3>
</div>
<div class="modal-body">
<div class="control-group">
<label class="control-label">
Group Name
</label>
<div class="controls">
<input type="text" id="GroupName" data-bind="value: GroupName" />
</div>
<label class="control-label">
Group Description
</label>
<div class="controls">
<input type="text" id="GroupDescription" data-bind="value: GroupDescription" />
</div>
<label class="control-label">Group Scope</label>
<div class="controls" id="scope">
<label class="radio">
<input type="radio" id="Local" name="Local" value="Local" />
Local
</label>
<label class="radio">
<input type="radio" id="Global" name="Global" value="Global" />
Global
</label>
<label class="radio">
<input type="radio" id="Universal" name="Universal" value="Universal" />
Universal
</label>
</div>
<div class="controls">
<label class="control-label">
Security
</label>
<input id="IsSecurity" type="checkbox" checked="checked" data-bind="value: IsSecurity" />
Is Security?
</div>
</div>
</div>
<div class="modal-footer">
<button class="btn" data-dismiss="modal" aria-hidden="true">Close</button>
<button class="btn btn-primary" id="CreateGroup" data-bind="click: vm.Save">Create Group</button>
</div>
</div>
视图模型:
vm = {
Data: ko.observable(),
Add: function () {
$("#ModalGroup").modal("show");
vm.Data(ko.utils.unwrapObservable(ko.mapping.fromJS({
GroupName: "",
GroupScope: "",
GroupDescription: ""
})));
if (!vm.Bound) {
ko.applyBindings(vm);
vm.Bound = true;
}
}
}
我尝试使用$('#ModalGroup').show('modal').on()
功能,然后我可以选择/取消选择我的单选按钮,但是我的绑定无法相应地工作。不知道如何将所有这些放在一起。
用于选择/删除的 Jquery:
$('input[type=radio]').change(function () {
if (this.checked) {
$(this).closest('.scope')
.find('input[type=radio]').not(this)
.prop('checked', false);
}
});
Jquery 是我在里面使用的$('#ModalGroup').show('modal').on()