テーブルのソート中に実行される「読み込みスピナー」をページに表示しようとすると問題が発生しました。特に低速のクライアントでは、ページのソートに最大 10 秒かかる場合があります。DOM がスピナー コードで変更されていることがわかりますが、表示されません。並べ替えが発生する前にこのスピナーの表示を強制し、並べ替えが完了したらもちろん停止するために何かできることを期待していました。
私のソートは「sorttable.js」に基づいており、テーブルの最初の列(名前が含まれている)で2番目のソートを処理するように変更しました。
私のスピナーは'spin.js'を使用しています。
私はまだこの jQuery の初心者であり、このソート可能なコードはかなり複雑です。以下の部分をハイライトしますが、完全に変更されたソートテーブル コード (今のところ) は'testing -ONLY-sort_and_spin.htm' の テスト html ページと共に'sorttable-TESTING-ONLY.js'にあります。
したがって、スクリプトはページの読み込み時にいくつかの機能を設定します (「.....」は行がスキップされることを意味します)。
makeSortable: function(table) { //line 75
......
headrow = table.tHead.rows[0].cells;
for (var i=0; i<headrow.length; i++) { //line 114
.....
headrow[i].sorttable_sortfunction = sorttable.guessType(table,i); //line 126
// code to start/stop spinner
headrow[i].sorttable_spinner = (function(val) { //line 136
return function(val) {
var $this = $(this),
data = $this.data();
if (data.spinner) {
data.spinner.stop();
delete data.spinner;
}
if (val > 0) {
var opts = {
.......
};
data.spinner = new Spinner($.extend({color: $this.css('color')}, opts)).spin(this);
// can see spinner added to DOM but does not display...
}
}})(i);
それらをコーディングすると、列ヘッダーのクリック可能なイベント ハンドラーが作成されます。
headrow[i].sorttable_columnindex = i; //line 171
headrow[i].sorttable_tbody = table.tBodies[0];
dean_addEvent(headrow[i],"click", function(e) { //line 176
.... does some stuff with class names, etc
this.sorttable_spinner(1); // set spinner on //line 224
.... builds array to do sort then calls sort functions
if (sort_direction == 'forward') { //line 247
row_array.sort(this.sorttable_sortfunction);
} else {
row_array.sort(this.sorttable_reversesortfunction);
}
tb = this.sorttable_tbody;
for (var j=0; j<row_array.length; j++) {
tb.appendChild(row_array[j][2]);
}
delete row_array;
this.sorttable_spinner(); // now stop the spinner //line 261
これはすべて機能しているように見えます。Firebug を使用した Firefox では、DOM にスピナー コードが読み込まれ、ブラウザーで回転し、スピナーをオフにする行で DOM から削除されます。しかし、デバッグモードでなく、実行しているだけの場合、スピナーは表示されませんか? (IE10 でデバッグしても、スピナーは表示されません)。
私はさまざまな場所で .show() を試しましたが、常に利用可能な関数ではないと言われます。window.setTimeout( function () {...
ソート用に別のプロセスを提供するための参照を見ましたが、この状況でそれを実装する方法を理解できませんでした。
誰かが私にいくつかの指針を与えることができれば、それは大歓迎です。
よろしく、 ブライス S.