ノックアウトを使用して階層を表示するツリービューを開発しました。私は、クロムの中で奇妙な状況に気付きました。これは、ツリーのノードを崩壊させるときに起こります。ノードのテキストは、その下の項目とともに消えます。私は自分のコードに何か問題があったと思って、それがIEとFirefoxの両方で正しく動作することを理解しました。私は、私のページから余分なコードを取り除いた問題を示す下のフィドルを作成しました。ノードを展開して折りたたむと(プラスボタンがフルコードのようにマイナスに変わらない)、テキストは消えます。次に、ページのどこかをクリックするだけで、テキストをバックアップして表示することができます。ノックアウトのChrome Bug?
消えたテキストが、私は4台のマシン上で、それがない各1でこれをテストしているコメントで推奨されているように赤で概説されており、スクリーンショット
で見ることができますChromeを使用しているときに動作します。これはChromeのバグですか、何か間違っていますか?また、Chromeのバグであれば誰でもこの問題を回避する方法はありますか?
console.clear();
var hierarchyNode = function (parent) {
var self = this;
this.name = "Node Name";
this.hasChildren = ko.observable(true);
this.childNodes = ko.observableArray();
this.expanded = ko.observable(false);
};
hierarchyNode.prototype = {
name: null,
hasChildren: null,
childNodes: null,
getChildNodes: function (element, event) {
if (element.hasChildren() === true && element.childNodes().length === 0) {
element.childNodes.push(new hierarchyNode(element));
}
element.expanded(!element.expanded());
}
};
var hierarchyVM = function() {
var self = this;
self.hierarchyNodes = ko.observableArray();
self.selectItem = function() {};
};
var vm = new hierarchyVM();
vm.hierarchyNodes.push(new hierarchyNode(null));
console.log(vm.hierarchyNodes()[0]);
ko.applyBindings(vm);
ul.tree {
list-style-type: none;
padding-left: 10px;
}
.hierarchyNode {border: 1px solid red;}
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul class="tree" data-bind="template: { name: 'itemTmpl', foreach: $data.hierarchyNodes }"></ul>
<script id="itemTmpl" type="text/html">
<li>
<button data-bind="click: getChildNodes">+</button>
<div data-bind="visible: hasChildren() == false" class="tree-spacer"></div>
<span data-bind="text: name" class="no_selection hierarchyNode"></span>
<ul class="tree" data-bind="template: { name: 'itemTmpl', foreach: $data.childNodes }, visible: expanded"></ul>
</li>
</script>
これはひどく奇妙な動作です... – Jeroen
Dev Toolbarの「Elements」タブに表示されていない「span」の上にカーソル*を置いて、実際にはテキストはありません。奇妙なことが起きている。誰かが別のWebkitブラウザでこれをチェックできるといいですね。 – Jeroen
'.hierarchyNode {border:1pxソリッドピンク; } 'を明確にするためにあなたの例に、おそらく[このスクリーンショット](http://i.stack.imgur.com/qdjSx.png)またはそれに類似しているので、人々は何を探すべきかを知っています。 – Jeroen