滾輪滾動事件

来源:https://www.cnblogs.com/SSPOFA/archive/2019/12/18/12064029.html
-Advertisement-
Play Games

滾輪滾動事件 ~~~javascript ~~~ ...


滾輪滾動事件

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <style type="text/css">
            #box1{
                width: 100px;
                height: 100px;
                background-color: skyblue;
            }
        </style>
        <script type="text/javascript">
            window.onload=function(){
                // 當滑鼠滾輪向下滾動時,box1變長
                // 當滾輪向上滾動時,box1變短
                
                var box1 = document.getElementById("box1");
                
                // 為box1綁定一個滑鼠滾輪滾動事件
                /*
                onmousewheel滑鼠滾輪滾動的事件,會在滾輪滾動時觸發
                但是火狐不支持該屬性
                
                
                在火狐中需要使用DOMMouseScroll 來綁定滾動時間
                  該事件需要通過addEventListener()函數調用
                */
                box1.onmousewheel=function(event){
                    event = event || window.event;
                    /*
                    判斷滑鼠滾輪滾動的方向
                    event.wheelDelta 可以獲取滑鼠滾輪滾動的方向
                    向上滾  120  向下滾 -120
                    wheelDelta這個值不看大小,只看正負
                    */
                   // alert(event.wheelDelta);
                   
                   // wheelDelta這個屬性火狐中不支持
                   // 在火狐中使用event.datail來獲取滾動
                   // 向上滾-3 向下滾3
                   
                   // alert(event.detail);
                   
                   
                   // 判斷滑鼠滾輪滾動的方向
                   if(event.wheelDelta > 0 || event.detail <0){
                       // alert("向上")
                       box1.style.height=box1.clientHeight-10+"px";
                   }else{
                        box1.style.height=box1.clientHeight+10+"px";
                   }
                   
                   /*
                   當滾輪滾動時,如果瀏覽器有滾動條,滾動條會隨之滾動
                   這是瀏覽起的預設行為  如果不希望發生  可以取消
                   */
                  return false;
                  
                  // 使用addEventListener()方法綁定響應函數,取消預設行為時不能使用return return false;
                  // 需要使用event來取笑預設行為 event.preventDefault();
                  // IE8不支持event.preventDefault();
                  event.preventDefault&&event.preventDefault();
                }
                
                bind(box1,"DOMMouseScroll",function(){
                    alert(1);
                })
            }
            function bind(obj,eventStr,callback){
                if(obj.addEventListener){
                    // 大部分瀏覽器相容的方式
                    obj.addEventListener(eventStr,callback,false);
                }else{
                    /*
                    this是誰由調用方式決定的
                    callbank.call(obj)
                    */
                    // IE8及以下
                    obj.attachEvent("on"+eventStr,function(){
                        // 在匿名函數中調用回掉函數
                        callback.call(obj);
                    });
                }
            }
            
        </script>
    </head>
    <body>
        <div id="box1"></div>
    </body>
</html>

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [20191218]降序索引疑問4.txt--//前幾天優化一個項目,我發現許多表裡面有有隱含欄位,一般開發很少建立函數索引.我自己檢查發現裡面存在大量的降序索引.--//我感覺有點奇怪,為什麼開發要建立大量降序索引有什麼好處呢?--//我在鏈接http://www.itpub.net/thread ...
  • 本章學習adt安卓打包過程、adb指令學習、並通過adb將打包的APK發給設備 1.打包 在eclipse中已經幫我們實現打包了. 具體打包流程如下: 最終一個APK包含瞭如下: classes.dex文件 (由class編譯過來的) resources.arsc文件 (編譯過的資源文件) Andr ...
  • 1.android中常用名詞介紹 ADT: ADT為Eclipse的插件。為Eclipse和SDK之間起了一個橋梁的作用。 SDK: 軟體開發工具包(Soft Development Kit),它為開發者提供了Android庫文件以及其它開發所用到的工具 JDK: java開發工具包,提供java工 ...
  • 最近在維護項目遇到一些奇葩的問題,自己研究了一下,但並沒有解決,再此做個記錄,路過的大牛還望,出個思路;再此,描述問題,以供大家研討1. MJRefresh 佈局問題ViewController裡面有兩個和self.View 一樣大小的View 一個 是添加了MJRefresh.mj_header ...
  • 我們有時候會向一個方法中傳入一個參數,並且對這個參數做一些處理的操作; 但是因為是引用傳遞,處理過後會對原有的對象造成修改,無法進行反覆使用。 如例子: 兩次列印的結果一模一樣。這樣下一個方法在繼續使用arr這個數的時候就不是["a","b","c"]這個值了,而是["a","b","c",2]; ...
  • HTML代碼 寫一個div來作為滑鼠區域 div中寫一個span顯示坐標信息 <body> <div id=""> <span></span> </div> </body> 給div和span增加樣式並定位 <style type="text/css"> div{ position: relativ ...
  • react中setState方法到底是非同步還是同步,其實這個是分在什麼條件下是非同步或者同步。 1.先來回顧一下react組件中改變state的幾種方式: import React, { Component } from 'react' class Index extends Component { ...
  • 在前端開發中,設置元素的 class 列表和內聯樣式是基本要求。本文主要講解Vue開發中,樣式列表和內聯樣式的綁定,僅供學習分享使用,如果有不足之處,還請指正。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...