Vue 無限滾動載入指令

来源:https://www.cnblogs.com/whnba/archive/2019/04/26/10775118.html
-Advertisement-
Play Games

也不存在什麼載入咯, 就是一個判斷滾動條是否到達瀏覽器底部了。 如果到了就觸發事件,米到就不處理。 計算公式提簡單的 底部等於(0) = 滾動條高度 - 滾動條頂部距離 - 可視高度。 反正結果就是0。 一、獲取滾動條位置 二、給根節點綁定滾動事件 vue給body元素綁定滾動條事件,真TMD草蛋。 ...


也不存在什麼載入咯, 就是一個判斷滾動條是否到達瀏覽器底部了。 如果到了就觸發事件,米到就不處理。

計算公式提簡單的   底部等於(0) =  滾動條高度 - 滾動條頂部距離 - 可視高度。  反正結果就是0。

 

一、獲取滾動條位置

class Scroll {
    static get top() {
        return Math.max(document.documentElement.scrollTop || document.body.scrollTop);
    }
    static get clientHeight() {
        return Math.max(document.documentElement.clientHeight || document.body.clientHeight);
    }
    static get clientWidth() {
        return Math.max(document.documentElement.clientWidth || document.body.clientWidth);
    }
    static get height() {
        return Math.max(document.documentElement.scrollHeight || document.body.scrollHeight);
    }
    static get width() {
        return Math.max(document.documentElement.scrollWidth || document.body.scrollWidth);
    }
    static get bottom() {
        return Scroll.height - Scroll.clientHeight - Scroll.top;
    }
}

 

二、給根節點綁定滾動事件

vue給body元素綁定滾動條事件,真TMD草蛋。事件綁定上去了 媽的 就是不觸發事件。不知道什麼鬼問題。

最後直接給根節點HTML綁定滾動事件。

const on = (function () {
    if (document.addEventListener) {
        return function (element, event, handler) {
            if (element && event && handler) {
                element.addEventListener(event, handler, false);
            }
        };
    } else {
        return function (element, event, handler) {
            if (element && event && handler) {
                element.attachEvent('on' + event, handler);
            }
        };
    }
})();

 

三、註冊全局指令

/**
 * 降低事件執行頻率
 */
const downsampler = (function () {
    let result = null;
    return function (time, func) {
        if (!result) {
            result = setTimeout(function () {
                func();
                result = null;
            }, time);
        }
    }
})();

 

Vue.directive("infinite-scroll", {
    bind(el, binding, vnode) {
        on(window, 'scroll', function () {
            if (typeof binding.value === "function" && Scroll.bottom <= 50) {   // 小於50就觸發
                downsampler(50, binding.value);  // 降低觸發頻率
            }
        })
    }
});

 

四、實例:

<div class="app" v-infinite-scroll="coupon">
       <template v-for="item in goods">
            <p>{{item}}</p>
      </template>
</div>
        let v = new Vue({
            el: ".app",
            data(){
                return {
                    goods:[]
                }
            },
            methods: {
                coupon() {
                    this.goods.push("你呵呵")
                }
            }
        })

 

演示地址:http://whnba.gitee.io/tkspa/


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

-Advertisement-
Play Games
更多相關文章
  • DOM元素經常會動態地綁定一些class類名或style樣式,本章將介紹使用v-bind指令來綁定class和style的多種方法。 ...
  • 這裡是預告 程式中經常有一些業務需要定製化,我定製化這些業務的方式主要是基於工作流、配置等方式。由於個人水平限制並不一定知道最好的方案是什麼。但卻希望有一種更通用的方案來處理。 雖然無代碼化並不是最終的追求,DSL在實用性方面還是具有獨到的優勢的。但是對於簡單的業務定製、甚至說不算是太複雜的業務,可 ...
  • [TOC] 1. HTML簡介 HTML由標簽和屬性構成的 1.1. HTML文檔基本結構 2. 標簽 學習html語言就是學習標簽的用法 2.1. 標簽語法 長在尖號後面第一個單詞就是標簽(標記,元素) 一組告訴瀏覽器如何處理一些內容的標簽,通過關鍵字來識別, 不同標簽代表不同含義,比如段落標簽、 ...
  • 先初始化棋盤 HTML: CSS: JS:// 棋盤 我們先讓每個棋子的value都為1,看看效果: 不要犯密集恐懼症哦, 我們用事件委托來綁定事件, 這樣事件只需要綁定一次而不用綁定15 * 15次, 很大地提升了效率, 開始寫點擊事件: 現在我們可以下棋了: 很有成就感是不是,就差最後一步也最是 ...
  • 參考:範仁義 js代碼: 在angularJS中使用過濾器過濾富文本數據 使用過濾器 ...
  • jquery照片牆 由15張圖片構成,大致思路:隨機生成所有圖片 點擊其中一張變為一張大圖 點擊大圖又變回多張 主要用到jquery實現 先來看看效果 html: css: js: 參考自:騰訊課堂渡一教育 ...
  • 本文作者:CODING 用戶 xfly 身邊經常會有小伙伴問我有沒有辦法不買伺服器也能上線自己的個人項目,比如不少同學都非常喜歡搭建一個屬於自己的博客站點或者小游戲等。 目前相對比較簡便的 且不花自己一分錢 的方法就是 Pages 服務。這類服務在國外比較知名的如 GitHub Pages 服務,在 ...
  • <div style="text-align:center;vertical-align:middel;"><input type="text"></div> 這樣左右上下都居中了。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...