bootstrap + knockout js 代码的默认选项卡

Posted

技术标签:

【中文标题】bootstrap + knockout js 代码的默认选项卡【英文标题】:Default tab for bootstrap + knockout js code 【发布时间】:2021-12-25 19:10:08 【问题描述】:

我不明白为什么这里的默认选项卡是参数,而不是车辆。启动时 - 参数正在打开,尽管我明确指出

self.curTab = ko.observable("车辆");

你可以在这里运行它http://jsfiddle.net/56gh1vpk/3/

function WebmailViewModel() 
    var self = this;
    self.curTab = ko.observable("vehicle");
  
  self.setCurTab = (curTab) => 
        self.curTab(curTab);
    


ko.applyBindings(new WebmailViewModel());
<link href="http://netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" rel="stylesheet"/>
<link href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap-theme.min.css" rel="stylesheet"/>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="http://netdna.bootstrapcdn.com/bootstrap/3.0.0/js/bootstrap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>

<ul class="nav nav-tabs nav-justified mb-3" role="tablist" >
                    <li>
                      <a data-bind="click: setCurTab('vehicle'), css: active: curTab() == 'vehicle'" >Vehicle</a>
                    </li>
                    <li>
                      <a data-bind="click: setCurTab('parameters'), css: active: curTab() == 'parameters'">Parameters</a>
                    </li>
  <div class="tab-content">
    <div role="tabpanel" class="tab-pane" data-bind="css: active: curTab() == 'vehicle'">Vehicle data</div>
    <div role="tabpanel" class="tab-pane" data-bind="css: active: curTab() == 'parameters'">Parameters data</div>
  </div>
  </ul>

【问题讨论】:

【参考方案1】:

经典的淘汰赛怪癖。这是因为点击绑定需要一个函数reference。当您说:click: setCurTab('parameters') 时,该函数实际上是在运行时执行的。将当前选项卡设置为“参数”,因为这是执行的最后一个函数调用。

您可以这样做:click: function () setCurTab('vehicle') ,或者如果您不喜欢匿名函数弄乱您的模板,请使用 bind:click: setCurTab.bind($data, 'vehicle')

【讨论】:

太棒了!感谢您的帮助!

以上是关于bootstrap + knockout js 代码的默认选项卡的主要内容,如果未能解决你的问题,请参考以下文章

bootstrap + knockout js 代码的默认选项卡

ASENET MVC 5 with Bootstrap and Knockout.js 第一弹

基于Bootstrap和Knockout.js的ASP.NET MVC开发实战 关于 拦截器的 学习 部分

持久化视图状态数据并中继到 Knockout.JS

knockout+bootstrap--一些复杂的应用合集

Knockout - 将样式应用于 Bootstrap Select 中的选定项目