Durandal 和 bootstrap-toggle
Durandal and bootstrap-toggle
我对 bootstrap-toggle (http://www.bootstraptoggle.com/) 和 durandal 有疑问。
我想用更大更好的切换开关替换普通复选框,以便移动用户可以更好地访问它们。
所以在 durandal 中,我在 index.html 中包含了 css(没有示例,因为与文档相同)和 main.js 中的 js:
requirejs.config({
paths: {
'text': '../lib/require/text',
'durandal':'../lib/durandal/js',
'plugins' : '../lib/durandal/js/plugins',
'transitions' : '../lib/durandal/js/transitions',
'knockout': '../lib/knockout/knockout-3.1.0',
'bootstrap': '../lib/bootstrap/js/bootstrap',
'bootstrap-toggle': '../lib/bootstrap/js/bootstrap-toggle.min',
'jquery': '../lib/jquery/jquery-1.9.1',
'toastr': '../lib/toastr/toastr.min',
'session': '../app/services/session',
'authentication': '../app/services/authentication',
'utility': '../app/services/utility',
'logger': '../app/services/logger'
},
shim: {
'bootstrap': {
deps: ['jquery'],
exports: 'jQuery'
}
}
});
在 shell.js 中我加载了模块(因为 bootstrap 默认不加载):
define(['plugins/router', 'knockout' ,'session', 'toastr','logger', 'durandal/app','bootstrap','bootstrap-switch']
, function (router, ko, session, toastr, logger, app, btstrps, btstrpsw) {
var showSplash = ko.observable(false);
//...
//routing etc...
阅读文档后,我想勾选复选框就足够了 'data-toggle':
<input checked data-toggle="toggle" type="checkbox" data-bind="checked: allCustomers" />
最近几个小时我一直在解决这个问题...也许有人遇到过类似的问题。我不知道 require-routine 是否正确加载了 toogle.js - 我该如何测试它?
您将需要使用 knockoutjs 绑定处理程序包装 bootstrapToggle,以在您的 observable 和 bootstrapToggle 小部件之间启用双向绑定。
请查看下面的代码片段以获取有效示例。
ko.bindingHandlers.bootstrapToggle = {
init: function(element, valueAccessor){
var observable = valueAccessor();
$(element).change(function(){ observable($(this).prop('checked')); });
var subscription = observable.subscribe(function(value){
$(element).bootstrapToggle(!!value ? "on" : "off");
});
ko.utils.domNodeDisposal.addDisposeCallback(element, function() {
subscription.dispose()
$(element).bootstrapToggle("destroy");
});
$(element).bootstrapToggle(!!valueAccessor()() ? "on" : "off");
}
}
var vm = {
allCustomers: ko.observable(true)
}
ko.applyBindings(vm);
setTimeout(function(){ vm.allCustomers(false); }, 2000);
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet">
<link href="https://gitcdn.github.io/bootstrap-toggle/2.2.0/css/bootstrap-toggle.min.css" rel="stylesheet">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
<script src="https://gitcdn.github.io/bootstrap-toggle/2.2.0/js/bootstrap-toggle.min.js"></script>
<input data-toggle="toggle" type="checkbox" data-bind="bootstrapToggle: allCustomers" />
<div data-bind="text: allCustomers">/</div>
或者,这里是一个具有相同工作示例的 fiddle。
我乐于接受关于可以实现双向绑定的更好的 bootstrapToggle 绑定处理程序的建议。
正如 Anish 已经提到的(再次感谢)您需要一个自定义绑定处理程序。为了更好地融入 durandal,我想展示我的解决方案:
mybinding.js
define(['knockout', 'jquery'], function (ko, $) {
ko.bindingHandlers.bootstrapToggle = {
init: function(element, valueAccessor){
var observable = valueAccessor();
$(element).change(function(){ observable($(this).prop('checked')); });
var subscription = observable.subscribe(function(value){
$(element).bootstrapToggle(!!value ? "on" : "off");
});
ko.utils.domNodeDisposal.addDisposeCallback(element, function() {
subscription.dispose()
$(element).bootstrapToggle("destroy");
});
$(element).bootstrapToggle(!!valueAccessor()() ? "on" : "off");
}
}
});
main.js
define(['durandal/system', 'durandal/app', 'durandal/viewLocator', 'toastr'], function (system, app, viewLocator, toastr) {
require(['bootstrap','bootstrap-toggle','mybinding']);
//>>excludeStart("build", true);
system.debug(true);
//>>excludeEnd("build");
app.configurePlugins({
router:true,
bootstrapModal: true
});
app.start()
.then(function() {
toastr.options.positionClass = 'toast-bottom-right';
toastr.options.backgroundpositionClass = 'toast-bottom-right';
viewLocator.useConvention();
app.setRoot('viewmodels/shell','entrance');
});
});
exampleView.html
<!-- some form markup-->
<input data-on="1" data-off="0" data-toggle="toggle" data-size="mini" type="checkbox"
data-bind="attr: { id: name }, bootstrapToggle: selected"/>
我对 bootstrap-toggle (http://www.bootstraptoggle.com/) 和 durandal 有疑问。 我想用更大更好的切换开关替换普通复选框,以便移动用户可以更好地访问它们。
所以在 durandal 中,我在 index.html 中包含了 css(没有示例,因为与文档相同)和 main.js 中的 js:
requirejs.config({
paths: {
'text': '../lib/require/text',
'durandal':'../lib/durandal/js',
'plugins' : '../lib/durandal/js/plugins',
'transitions' : '../lib/durandal/js/transitions',
'knockout': '../lib/knockout/knockout-3.1.0',
'bootstrap': '../lib/bootstrap/js/bootstrap',
'bootstrap-toggle': '../lib/bootstrap/js/bootstrap-toggle.min',
'jquery': '../lib/jquery/jquery-1.9.1',
'toastr': '../lib/toastr/toastr.min',
'session': '../app/services/session',
'authentication': '../app/services/authentication',
'utility': '../app/services/utility',
'logger': '../app/services/logger'
},
shim: {
'bootstrap': {
deps: ['jquery'],
exports: 'jQuery'
}
}
});
在 shell.js 中我加载了模块(因为 bootstrap 默认不加载):
define(['plugins/router', 'knockout' ,'session', 'toastr','logger', 'durandal/app','bootstrap','bootstrap-switch']
, function (router, ko, session, toastr, logger, app, btstrps, btstrpsw) {
var showSplash = ko.observable(false);
//...
//routing etc...
阅读文档后,我想勾选复选框就足够了 'data-toggle':
<input checked data-toggle="toggle" type="checkbox" data-bind="checked: allCustomers" />
最近几个小时我一直在解决这个问题...也许有人遇到过类似的问题。我不知道 require-routine 是否正确加载了 toogle.js - 我该如何测试它?
您将需要使用 knockoutjs 绑定处理程序包装 bootstrapToggle,以在您的 observable 和 bootstrapToggle 小部件之间启用双向绑定。
请查看下面的代码片段以获取有效示例。
ko.bindingHandlers.bootstrapToggle = {
init: function(element, valueAccessor){
var observable = valueAccessor();
$(element).change(function(){ observable($(this).prop('checked')); });
var subscription = observable.subscribe(function(value){
$(element).bootstrapToggle(!!value ? "on" : "off");
});
ko.utils.domNodeDisposal.addDisposeCallback(element, function() {
subscription.dispose()
$(element).bootstrapToggle("destroy");
});
$(element).bootstrapToggle(!!valueAccessor()() ? "on" : "off");
}
}
var vm = {
allCustomers: ko.observable(true)
}
ko.applyBindings(vm);
setTimeout(function(){ vm.allCustomers(false); }, 2000);
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet">
<link href="https://gitcdn.github.io/bootstrap-toggle/2.2.0/css/bootstrap-toggle.min.css" rel="stylesheet">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
<script src="https://gitcdn.github.io/bootstrap-toggle/2.2.0/js/bootstrap-toggle.min.js"></script>
<input data-toggle="toggle" type="checkbox" data-bind="bootstrapToggle: allCustomers" />
<div data-bind="text: allCustomers">/</div>
或者,这里是一个具有相同工作示例的 fiddle。
我乐于接受关于可以实现双向绑定的更好的 bootstrapToggle 绑定处理程序的建议。
正如 Anish 已经提到的(再次感谢)您需要一个自定义绑定处理程序。为了更好地融入 durandal,我想展示我的解决方案:
mybinding.js
define(['knockout', 'jquery'], function (ko, $) {
ko.bindingHandlers.bootstrapToggle = {
init: function(element, valueAccessor){
var observable = valueAccessor();
$(element).change(function(){ observable($(this).prop('checked')); });
var subscription = observable.subscribe(function(value){
$(element).bootstrapToggle(!!value ? "on" : "off");
});
ko.utils.domNodeDisposal.addDisposeCallback(element, function() {
subscription.dispose()
$(element).bootstrapToggle("destroy");
});
$(element).bootstrapToggle(!!valueAccessor()() ? "on" : "off");
}
}
});
main.js
define(['durandal/system', 'durandal/app', 'durandal/viewLocator', 'toastr'], function (system, app, viewLocator, toastr) {
require(['bootstrap','bootstrap-toggle','mybinding']);
//>>excludeStart("build", true);
system.debug(true);
//>>excludeEnd("build");
app.configurePlugins({
router:true,
bootstrapModal: true
});
app.start()
.then(function() {
toastr.options.positionClass = 'toast-bottom-right';
toastr.options.backgroundpositionClass = 'toast-bottom-right';
viewLocator.useConvention();
app.setRoot('viewmodels/shell','entrance');
});
});
exampleView.html
<!-- some form markup-->
<input data-on="1" data-off="0" data-toggle="toggle" data-size="mini" type="checkbox"
data-bind="attr: { id: name }, bootstrapToggle: selected"/>