[解決]3D組件的縮放與頁面滾動沖突

在 Web 開發(fā)中,使用 3D 組件展示內(nèi)容已經(jīng)變得越來越普遍构捡,通常希望通過鼠標(biāo)滾輪來對 3D 組件進(jìn)行縮放操作,但在同一頁面上壳猜,y軸滾動條也可能存在勾徽,這樣一來,當(dāng)滾輪操作時统扳,既會觸發(fā) 3D 組件的縮放喘帚,又會導(dǎo)致頁面的滾動,那么如何優(yōu)雅地解決這個問題咒钟?

問題描述:

頁面中包含 3D 組件展示區(qū)以及一些其他內(nèi)容吹由,滾動鼠標(biāo)滾輪時,不僅會對 3D 組件進(jìn)行縮放朱嘴,同時頁面也會跟著滾動倾鲫,如下圖所示:


修改前
解決方案概述:
  • 要實(shí)現(xiàn)的目標(biāo):
  1. 在用戶鼠標(biāo)放置 3D 組件展示區(qū)滾動鼠標(biāo)滾輪時 3D 組件跟隨縮放,但頁面不會跟著滾動萍嬉。
  2. 當(dāng)用戶鼠標(biāo)放置在 3D 組件展示區(qū)之外滾動鼠標(biāo)滾輪時乌昔,3D 組件不會跟隨縮放,頁面會上下滾動壤追。
  • 實(shí)現(xiàn)這一目標(biāo)磕道,采取以下思路:
  1. 確保只有當(dāng)鼠標(biāo)位于 3D 組件區(qū)域時,才阻止頁面滾動行冰。
具體實(shí)現(xiàn):
1. 添加鼠標(biāo)滾輪事件監(jiān)聽器:
const containerRef = useRef(null);

useEffect(() => {
    const container: any = containerRef.current;
    //passive: false在特定情況下阻止頁面滾動
    container.addEventListener('wheel', handleWheel, { passive: false });
    return () => {
      container.removeEventListener('wheel', handleWheel);
    };
  }, []);

containerRef 為頁面滾動區(qū)域的元素溺蕉。

2. 使用 closest 方法判斷事件目標(biāo):

為了確保只有當(dāng)鼠標(biāo)位于 3D 組件區(qū)域時才阻止頁面滾動,使用 closest 方法來判斷 event.target 是否屬于我們定義的 3D 組件容器悼做。

  const handleWheel = useCallback((event: any) => {
    // 阻止頁面默認(rèn)的滾動行為
    if (event.target.closest('#rootGeo3DCanvas')) {
      event.preventDefault();
    }
  }, []);

event.target.closest('#3d-container') 會從事件的目標(biāo)元素開始向上查找疯特,直到找到與選擇器 #rootGeo3DCanvas 匹配的祖先元素。如果找到了贿堰,則表示鼠標(biāo)當(dāng)前位于 3D 組件區(qū)域內(nèi)辙芍。通過 event.preventDefault() 來阻止頁面默認(rèn)的滾動行為。

解決后的效果:
修改后
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末羹与,一起剝皮案震驚了整個濱河市故硅,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌纵搁,老刑警劉巖吃衅,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異腾誉,居然都是意外死亡徘层,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門利职,熙熙樓的掌柜王于貴愁眉苦臉地迎上來趣效,“玉大人,你說我怎么就攤上這事猪贪□尉矗” “怎么了?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵热押,是天一觀的道長西傀。 經(jīng)常有香客問我,道長桶癣,這世上最難降的妖魔是什么拥褂? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮牙寞,結(jié)果婚禮上饺鹃,老公的妹妹穿的比我還像新娘。我一直安慰自己间雀,他們只是感情好尤慰,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著雷蹂,像睡著了一般伟端。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上匪煌,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天责蝠,我揣著相機(jī)與錄音,去河邊找鬼萎庭。 笑死霜医,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的驳规。 我是一名探鬼主播肴敛,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了医男?” 一聲冷哼從身側(cè)響起砸狞,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎镀梭,沒想到半個月后刀森,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡报账,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年研底,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片透罢。...
    茶點(diǎn)故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡榜晦,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出羽圃,到底是詐尸還是另有隱情乾胶,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布统屈,位于F島的核電站胚吁,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏愁憔。R本人自食惡果不足惜腕扶,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望吨掌。 院中可真熱鬧半抱,春花似錦、人聲如沸膜宋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽秋茫。三九已至史简,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間肛著,已是汗流浹背圆兵。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留枢贿,地道東北人殉农。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓,卻偏偏與公主長得像局荚,于是被迫代替她去往敵國和親超凳。 傳聞我的和親對象是個殘疾皇子愈污,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容