[解決済み] 内部要素のスクロール位置が上/下に達したときに親要素のスクロールを防止しますか?
2022-04-07 09:41:55
質問
小さなフローティングツールボックスを作成しました。
position:fixed; overflow:auto
.
問題なく動作しています。
しかし、そのボックスの内側を (マウス ホイールで) スクロールして、下部または上部に到達すると、親要素が "takes over" the "scroll request" : ツールボックスの後ろのドキュメントがスクロールされるのです。
- これは迷惑なことであり、ユーザーが求めているものではありません。
jQueryを使っているので、event.stoppropagation()でこの挙動を止められると思ったのですが。
$("#toolBox").scroll( function(event){ event.stoppropagation() });
関数に入りますが、それでもとにかく伝搬が起こります(ドキュメントがスクロールします)。
- SO(とGoogle)でこの話題を検索するのは意外と難しいので、質問させていただきました。
scroll-eventの伝搬/バブリングを防ぐには?
編集する。
amustill(とBrandon Aaronによるmousewheel-plugin)により、解決されました。
https://github.com/brandonaaron/jquery-mousewheel/raw/master/jquery.mousewheel.js
$(".ToolPage").bind('mousewheel', function(e, d)
var t = $(this);
if (d > 0 && t.scrollTop() === 0) {
e.preventDefault();
}
else {
if (d < 0 && (t.scrollTop() == t.get(0).scrollHeight - t.innerHeight())) {
e.preventDefault();
}
}
});
どのように解決するのですか?
ブランドン・アーロンの使用で可能です。 マウスホイールプラグイン .
ここでは、そのデモをご紹介します。 http://jsbin.com/jivutakama/edit?html,js,output
$(function() {
var toolbox = $('#toolbox'),
height = toolbox.height(),
scrollHeight = toolbox.get(0).scrollHeight;
toolbox.bind('mousewheel', function(e, d) {
if((this.scrollTop === (scrollHeight - height) && d < 0) || (this.scrollTop === 0 && d > 0)) {
e.preventDefault();
}
});
});
関連
-
[解決済み】TypeError: $(...).DataTable は関数ではありません。
-
[解決済み】別のjsファイル内でJavaScriptの関数を呼び出す
-
[解決済み】npm install --legacy-peer-deps は具体的に何をするのですか?どんなときに推奨されるのか/どんな使用例が考えられるのか?
-
[解決済み】TypeError: res.status は関数ではありません。
-
[解決済み】Uncaught ReferenceError。Firebase は定義されていません。
-
[解決済み】Syntax error: JavaScriptの不正なreturnステートメント
-
[解決済み】Uncaught TypeError: 未定義のプロパティ 'msie' を読み取れない - jQuery tools
-
[解決済み】未定義のプロパティ 'forEach' を読み取ることができない
-
[解決済み] ListViewに戻ったときのスクロール位置の維持/保存/復元
-
[解決済み] モーダルが開かれたときにBODYがスクロールしないようにする
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】TypeError: 'undefined'はオブジェクトではありません。
-
[解決済み】コンソールがUnterminated JSX contentsエラーを投げる【終了しました
-
[解決済み】SyntaxError: JSON の位置 1 に予期しないトークン o があります。
-
[解決済み】エラー:リスン EACCES 0.0.0.0:80 OSx Node.js
-
[解決済み】JavaScriptで相対URLへのリダイレクトを行う
-
[解決済み】TypeError:res.jsonは関数ではありません。
-
[解決済み】Syntax error: JavaScriptの不正なreturnステートメント
-
[解決済み】HTMLの最初の行に予期しないトークン<がある。
-
[解決済み】中央値の計算 - javascript
-
[解決済み] ブラウザ間のマウスホイール速度の正規化