[解決済み] React.jsのonScrollでコンポーネントのスタイルを更新する
2022-03-15 22:45:42
質問
私はReactでコンポーネントを構築しました。それは、パララックス効果を作成するために、ウィンドウのスクロール時にそれ自身のスタイルを更新することになっています。
コンポーネント
render
メソッドは次のようになります。
function() {
let style = { transform: 'translateY(0px)' };
window.addEventListener('scroll', (event) => {
let scrollTop = event.srcElement.body.scrollTop,
itemTranslate = Math.min(0, scrollTop/3 - 60);
style.transform = 'translateY(' + itemTranslate + 'px)');
});
return (
<div style={style}></div>
);
}
これは、React がコンポーネントが変更されたことを知らないため、コンポーネントの再レンダリングが行われないので、うまくいきません。
の値を保存してみました。
itemTranslate
をコンポーネントの状態で呼び出すと
setState
をスクロールコールバックで使用します。しかし、これではスクロールが恐ろしく遅くなり、使い物にならない。
何かいい方法はないでしょうか?
どのように解決するのですか?
リスナーを
componentDidMount
そうすれば、一度だけ作成されます。リスナーはおそらくパフォーマンスの問題の原因でした。
こんな感じかな。
componentDidMount: function() {
window.addEventListener('scroll', this.handleScroll);
},
componentWillUnmount: function() {
window.removeEventListener('scroll', this.handleScroll);
},
handleScroll: function(event) {
let scrollTop = event.srcElement.body.scrollTop,
itemTranslate = Math.min(0, scrollTop/3 - 60);
this.setState({
transform: itemTranslate
});
},
関連
-
JavaScriptのクロージャの説明
-
Vueのフォームイベントのデータバインディングの説明
-
[解決済み】JavaScript TypeError: null のプロパティ 'style' を読み取ることができない
-
[解決済み】ExpressJS - throw er Unhandled errorイベント
-
[解決済み】React.jsの配列の子要素のユニークキーを理解する
-
[解決済み] setStateを呼び出さずにReactコンポーネントを強制的に再レンダリングすることは可能ですか?
-
[解決済み] Reactコンポーネント外でのクリックを検出する
-
[解決済み] ReactJSでコンポーネントがtext型の非制御入力を制御エラーに変更する場合
-
[解決済み】React.jsで親コンポーネントにpropsを渡す。
-
[解決済み】React.jsの状態配列の正しい修正について
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
fetch ネットワークリクエストラッパーの説明例
-
JavaScriptのクロージャの説明
-
vueはopenlayersを使用してスカイマップとガオードマップをロードする
-
[解決済み】Node.js getaddrinfo ENOTFOUND
-
[解決済み】Node Version Manager のインストール - nvm コマンドが見つかりません。
-
[解決済み】「X-Frame-Options」を「SAMEORIGIN」に設定したため、フレームでの表示を拒否された。
-
[解決済み] 期待される代入または関数呼び出し: 未使用式なし ReactJS
-
[解決済み] Web API エラー - このリクエストはブロックされました; コンテンツは HTTPS で提供されなければなりません
-
JavaScriptのgetElementById()メソッド入門
-
jq は html ページとデータを動的に分割する。