【问题标题】:Durandal and bootstrap-toggleDurandal 和引导切换
【发布时间】:2015-07-02 14:58:54
【问题描述】:

我对 bootstrap-toggle (http://www.bootstraptoggle.com/) 和 durandal 有疑问。 我想用更大更好的拨动开关替换普通的复选框,以便移动用户可以更好地访问它们。

所以在 durandal 中,我将 css 包含在 index.html 中(没有示例,因为与文档相同)和 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 中,我加载了模块(因为默认情况下不加载引导程序):

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...

阅读文档后,我认为将复选框设置为“数据切换”就足够了:

<input checked data-toggle="toggle" type="checkbox" data-bind="checked: allCustomers" />

过去几个小时我一直在解决这个问题......也许有人遇到过类似的问题。我不知道 require-routine 是否正确加载了 toogle.js - 我该如何测试呢?

【问题讨论】:

    标签: javascript css twitter-bootstrap toggle durandal


    【解决方案1】:

    您需要用一个 knockoutjs 绑定处理程序包装 bootstrapToggle,以在您的 observable 和 bootstrapToggle 小部件之间启用双向绑定。

    请查看下面的 sn-p 以获取工作示例。

    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,我通过 require('mybinding') 让它工作了,我在其中定义了自定义绑定...顺便说一句:自定义绑定似乎很有趣 ;)
    【解决方案2】:

    正如 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"/>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2015-03-03
      • 2016-11-16
      • 2017-05-28
      • 1970-01-01
      • 1970-01-01
      • 2019-06-23
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多