私はBootstrap Table extensionを自分のアプリケーションに統合しようとしています。それは一般的にはうまくいきますが、私はノックアウト観測で拘束力を失う問題があります。Wenzhixinのブートストラップテーブルを破るKnockout.jsバインディング
このコードavailable on JSFiddleはこの問題を示しています。テーブルに対してbootstrapTable()が呼び出されると、テキストボックスへのバインドが中断されます。最後の行をコメントアウトすると、すべてがうまくいきます。私が見
Javascriptを
var order = {
Id: 1,
CustomerName: 'A Customer',
Lines: [{
ProductCode: 'Prod_1',
Cost: 11.11,
Qty: 1
}, {
ProductCode: 'Prod_2',
Cost: 22.22,
Qty: 2
}, {
ProductCode: 'Prod_3',
Cost: 33.33,
Qty: 3
}, ]
};
var orderMapping = {
'Lines': {
create: function(options) {
return new orderLineViewModel(options.data);
}
}
}
var orderLineViewModel = function(data) {
var self = this;
if (data != null) {
ko.mapping.fromJS(data, {}, this);
}
self.LineValue = ko.computed(function() {
return (self.Cost() * self.Qty()).toFixed(2);
});
};
var orderViewModel = function(data) {
var self = this;
ko.mapping.fromJS(data, orderMapping, this);
};
var viewModel = new orderViewModel(order);
ko.applyBindings(viewModel);
//Removing the line below results in ko working fine
$('#OrderTable').bootstrapTable({});
HTML
<table id="OrderTable" class="table">
<thead>
<tr>
<th>Product</th>
<th>Line Value</th>
<th>Cost</th>
<th>Qty</th>
</tr>
</thead>
<tbody data-bind="foreach: Lines">
<tr>
<td><span data-bind="text: ProductCode"></span></td>
<td><span data-bind="text: LineValue"></span></td>
<td><span data-bind="text: Cost"></span></td>
<td>
<input type="text" data-bind="value: Qty" />
</td>
</tr>
</tbody>
</table>
ありがとうございますtyler_mitchell。私は間違ってフィドルの間違ったバージョンを投稿しました!私は質問を更新しましたが、おそらく私は質問を閉じて再開する必要がありますか?私はS/Oを初めて熟知しています。 – Scott