首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >杜兰达尔和自举开关

杜兰达尔和自举开关
EN

Stack Overflow用户
提问于 2015-07-02 14:58:54
回答 2查看 646关注 0票数 2

我对引导切换(http://www.bootstraptoggle.com/)和硬膜有问题.我想用更大更好的切换开关来代替普通的复选框,这样移动用户就可以更好地访问它们。

因此,在durandal中,我在index.html中包含了css (没有示例,因为它与docs相同)和main.js中的js:

代码语言:javascript
复制
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中,我加载模块(默认情况下,引导程序不是加载的):

代码语言:javascript
复制
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...

在阅读了这些文档之后,我认为这足以使复选框“数据切换”:

代码语言:javascript
复制
<input checked data-toggle="toggle" type="checkbox" data-bind="checked: allCustomers" />

过去几个小时我一直在处理这个问题.也许有人也经历过类似的问题。我不知道需求例程是否正确地加载了toogle.js -我如何测试这个?

EN

Stack Overflow用户

发布于 2015-07-02 16:11:18

您将需要将bootstrapToggle封装为一个knockoutjs绑定处理程序,以启用可观察到的和bootstrapToggle小部件之间的双向绑定。

请查看下面的代码片段以获得一个工作示例。

代码语言:javascript
复制
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);
代码语言:javascript
复制
<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>

或者,下面是一个具有相同工作示例的小提琴

我愿意接受关于一个更好的bootstrapToggle绑定处理程序的建议,它可以实现双向绑定。

票数 1
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31188054

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档