ホームページ ウェブフロントエンド htmlチュートリアル ExtJs 4.2.1グリッド行編集後のページスクロールの解決策_html/css_WEB-ITnose

ExtJs 4.2.1グリッド行編集後のページスクロールの解決策_html/css_WEB-ITnose

Jun 24, 2016 am 11:52 AM

少し前に、当社の開発チームは ExtJs4.2.1Mvc モデルを選択しました。開発プロセス中に多くの問題に遭遇しました (専門外の要求担当者がさまざまな要件を提示したのは避けられませんでした)。気まぐれ)、API をチェックして 1 つずつ解決した後、今後のレビューのために、また ExtJ を初めて使用するネチズンが説明を理解できるように、開発プロセス中に発生した問題と解決した問題を記録します。正しい位置にあるか、間違いがある場合は、修正していただければ幸いです。 (注: 以下に挙げるメソッドはすべて ExtJs ライブラリ内のメソッドであり、js ネイティブではありません)

プロジェクト全体が ExtJs の MVC を使用しているため、プロジェクトは基本的にすべて js ファイルです (カスタマイズされた js ファイル 100 近く、そうでないもの) ExtJs ライブラリについては言及してください)、パフォーマンスの問題は言うまでもなく、ページの読み込みが非常に遅くなります。これは長年の問題です。

質問 1:

グリッド ページのスクロールの問題に関しては、このグリッドには 2 種類のデータがあり、1 つは使用可能なデータ、もう 1 つは使用可能なデータです。データは正常に表示され、無効なデータは灰色で表示されます (灰色の表示は、グリッドの viewConfig の getRowClass 属性を使用して実現できます。次のようになります:

getRowClass: function(record, rowIndex, rowParams,store){
return (record.get('youxiao1' ) == 0 || Record.get('iseit') == 0) ? 'row-valid' :' ';
}

);

このグリッドは編集可能であり、混乱なく 2 種類のデータを表示するために、ユーザーは常にグリッドの内容をスクロールする必要がありません。グリッドを編集するので、それについて考えてほしいとのことで、方法を探していたので、この要件を完璧にするために 2 日を費やしました (その過程で、それを達成するために 3 つの方法を使用しました。3 番目の方法が最も完璧です)。 :

方法 1: focusRow( row, [lay] ) を直接使用し、特定の行にフォーカスさせます

方法 2: 現在編集中の行とグリッドの最初の行のレコードを取得し、垂直距離を計算します。 getOffsetsTo() メソッドを使用してグリッド内の 2 行のレコードを取得し、スクロール バーをこの距離値の位置までスクロールします。これですべてです。このロジックはグリッドの viewConfig 構成に実装され、行の編集後に Grid.getView().XXX() を通じて呼び出されます。 viewConfig に次の 2 つのメソッドを追加します:

//指定された Record にグリッドをスクロールします
scrollToRecord:function(record){
varindex = this.ownerCt.getStore().indexOf(record)
this.scrollToRow(index ;
var row = Ext.get(this.getNode(rowIndex)); // 現在編集中の行
var distance = row.getOffsetsTo(firstRow)[1] // 垂直距離を取得します.scroller はないようですこの属性は Ext4.x にありますが、3.x にのみ存在しますか?
This.getEl().setScrollTop( distance); // スクロール バーを設定します
}

方法 3: 最初の 2 つの方法もニーズを満たすことができますが、完璧ではありません。これも最も単純です。

行を編集する前に、まず現在のスクロールバーの位置を取得します: varscrollTop =grid.getView().getEl().getScrollTop(); //ソートの前に、グリッドスクロールバーのscrollTop

ソート後編集が完了したら、スクロール バーをスクロールして初期位置に戻します。 Grid.getView().getEl().setScrollTop(scrollTop); グリッドに固定列がある場合、または一部の列がロックされている場合: true 属性を設定すると、ロックされたグリッドのビューを直接取得できないため、無効になります。スクロールする場合は、両方のビューをスクロールする必要があります。そうしないと、テーブルがスクロールされます。ああ〜〜、これを知った上で他の設定は上記と同じになります!

質問 1 が完了しました。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

HTMLは初心者のために簡単に学ぶことができますか? HTMLは初心者のために簡単に学ぶことができますか? Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTML、CSS、およびJavaScriptの役割:コアの責任 HTML、CSS、およびJavaScriptの役割:コアの責任 Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTML、CSS、およびJavaScriptの理解:初心者向けガイド HTML、CSS、およびJavaScriptの理解:初心者向けガイド Apr 12, 2025 am 12:02 AM

webdevelopmentReliesOnhtml、css、andjavascript:1)htmlStructuresContent、2)cssStylesit、および3)Javascriptaddsinteractivity、形成、

HTMLでの開始タグの例は何ですか? HTMLでの開始タグの例は何ですか? Apr 06, 2025 am 12:04 AM

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Apr 04, 2025 pm 11:54 PM

GiteEpages静的Webサイトの展開が失敗しました:404エラーのトラブルシューティングと解像度Giteeを使用する

WebアノテーションにY軸位置の適応レイアウトを実装する方法は? WebアノテーションにY軸位置の適応レイアウトを実装する方法は? Apr 04, 2025 pm 11:30 PM

Y軸位置Webアノテーション機能の適応アルゴリズムこの記事では、単語文書と同様の注釈関数、特に注釈間の間隔を扱う方法を実装する方法を探ります...

HTML、CSS、およびJavaScript:Web開発者に不可欠なツール HTML、CSS、およびJavaScript:Web開発者に不可欠なツール Apr 09, 2025 am 12:12 AM

HTML、CSS、およびJavaScriptは、Web開発の3つの柱です。 1。HTMLは、Webページ構造を定義し、などなどのタグを使用します。2。CSSは、色、フォントサイズなどのセレクターと属性を使用してWebページスタイルを制御します。

CSS3とJavaScriptを使用して、クリック後に周囲の写真を散乱および拡大する効果を実現する方法は? CSS3とJavaScriptを使用して、クリック後に周囲の写真を散乱および拡大する効果を実現する方法は? Apr 05, 2025 am 06:15 AM

画像をクリックした後、散乱と周囲の画像を拡大する効果を実現するには、多くのWebデザインがインタラクティブな効果を実現する必要があります。特定の画像をクリックして周囲を作成してください...

See all articles