js實現單張或多張圖片持續無縫滾動

来源:https://www.cnblogs.com/beileixinqing/archive/2020/05/08/12852938.html
-Advertisement-
Play Games

背景: 想要實現圖片持續滾動,既然使用js,就千萬不要加css動畫、過渡等相關樣式,如果想要滾動的平滑一下,可以一像素一像素的感動,則很平滑,如果加了過渡動畫,當圖片重置為0時,會有往回倒的動畫效果,跟預期不符。 原理: 圖片滾動原理同圖片輪播原理,同樣也適用於文字滾動等一系列滾動,通過複製最後一張 ...


背景:

想要實現圖片持續滾動,既然使用js,就千萬不要加css動畫、過渡等相關樣式,如果想要滾動的平滑一下,可以一像素一像素的感動,則很平滑,如果加了過渡動畫,當圖片重置為0時,會有往回倒的動畫效果,跟預期不符。

原理:

圖片滾動原理同圖片輪播原理,同樣也適用於文字滾動等一系列滾動,通過複製最後一張圖片或最後一堆文字插入第一行,或複製第一張圖片或一堆文字插入在結尾,來實現無縫拼接,前提:1、必須是沒有設置過渡動畫的,2、重置為0的時候與當前已經滾動到的高度對於圖片的位置而言肉眼看上去沒變化。

實現:

html主要包含三塊:

1、最外層盒子,用來展示滾動圖的區域,overflow:hidden;

2、滾動的盒子,主要改變該盒子的定位值,來實現滾動,裡面包含所有要滾動的圖片或文字

3、包含圖片或文字的盒子。

 

代碼:

class Roll {
    constructor(opts) {
        this.elem = opts.elem; // 圖片包含滾動長度的元素的
        this.elemBox = opts.elemBox; //圖片展示區域元素,為了獲取展示區域的高度
        this.direction = opts.direction;
        this.time = opts.time;
        this.init();
        this.roll = this.roll.bind(this)
        this.startRoll = this.startRoll.bind(this)
        this.stopRoll = this.stopRoll.bind(this)
    }
    init(){
        this.elemHeight = this.elem.offsetHeight;
        this.elemHtml = this.elem.innerHTML;
        this.elem.innerHTML = this.elem.innerHTML + this.elemHtml+ this.elemHtml;
        this.speed;
        // 如果向上滾或者向左滾動每次減1,向下滾或者向右滾動每次加1
        if(this.direction === 'top' || this.direction === 'left'){
            this.speed = -1;
        }else{
            this.speed = 1;
        }
    }
    roll(){
        switch (this.direction) {
            case "top":
                // 如果滾動的盒子的top值超出元素的高度,則置為0
                if(Math.abs(this.elemBox.offsetTop) >= this.elemHeight){
                    this.elemBox.style.top = 0;
                }else{
                    this.elemBox.style.top = this.elemBox.offsetTop + this.speed + 'px';
                }
                break;
            case "bottom":
                // 如果滾動的盒子的bottom值超出元素的高度,則置為0
                if(Math.abs(this.elemBox.offsetBottom) >= this.elemHeight){
                    this.elemBox.style.bottom = 0;
                }else{
                    this.elemBox.style.bottom = this.elemBox.offsetBottom + this.speed + 'px';
                }
                break;
            case "left":
                // 如果滾動的盒子的left超出元素的高度,則置為0
                if(Math.abs(this.elemBox.offsetLeft) >= this.elemHeight){
                    this.elemBox.style.left = 0;
                }else{
                    this.elemBox.style.left = this.elemBox.offsetLeft + this.speed + 'px';
                }
                break;
            case "right":
                // 如果滾動的盒子的right超出元素的高度,則置為0
                if(Math.abs(this.elemBox.offsetRight) >= this.elemHeight){
                    this.elemBox.style.right = 0;
                }else{
                    this.elemBox.style.right = this.elemBox.offsetRight + this.speed + 'px';
                }
                break;
            default:
                // 預設向上滾動,如果滾動的盒子的top超出元素的高度,則置為0
                if(Math.abs(this.elemBox.offsetTop) >= this.elemHeight){
                    this.elemBox.style.top = 0;
                }else{
                    this.elemBox.style.top = this.elemBox.offsetTop + speed + 'px';
                }
        }
    }
    stopRoll(){
        clearInterval(this.scrollTimer)
    }
    startRoll(){
        this.scrollTimer = setInterval(this.roll,this.time)
    }
}

 

參考鏈接:

https://www.teakki.com/p/590beb7be8136dfc5f21770d


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

-Advertisement-
Play Games
更多相關文章
  • 隨著諸如Apache Flink,Apache Spark,Apache Storm之類的開源框架以及諸如Google Dataflow之類的雲框架的增多,創建實時數據處理作業變得非常容易。這些API定義明確,並且諸如Map Reduce之類的標準概念在所有框架中都遵循幾乎相似的語義。 但是,直到今 ...
  • 最近在Java技術棧公眾號發佈的一篇文章,其中有一道題: Redis是多線程還是單線程?(回答單線程的請回吧,為什麼請回,請往下看) 好些粉絲在後臺問我: 為什麼請回,Redis不是單線程嗎? 大家註意審題: Redis是多線程還是單線程? 這個問題你要從多個方面回答,如果你僅僅只回答 "單線程" ...
  • 【目錄】 一、IDE工具介紹與安裝使用——navicat 神器 二、MySQL數據備份 三、pymysql模塊 1、安裝 2、使用模塊 一、IDE工具介紹與安裝使用——navicat 神器 https://www.cnblogs.com/bigorangecc/p/12851845.html 二、M ...
  • 一、碎片的狀態和 1.運行狀態 當一個碎片是可見的,並且她所關聯的活動正處於運行狀態,該碎片就是運行​狀態。 2.暫停狀態 當一個活動那個進入暫停狀態(由於另一個未占滿屏幕的活動被添加到棧頂),與它相關聯的​可見碎片進入到暫停狀態。 3.停止狀態 當一個活動進入到停止狀態的時候,與它相關聯的碎片就會 ...
  • 一、什麼是事件分發 所謂事件分發,就是將一次完整的點擊所包含的點擊事件傳遞到某個具體的View或ViewGroup,讓該View或該ViewGroup處理它(消費它)。分發是從上往下(父到子)依次傳遞的,其中可能經過的對象有最上層Activity,中間層ViewGroup,最下層View。 二、Ac ...
  • 1、需求 首先、針對UILabel中顯示的多個功能標簽,作出顏色標記提示。 其次、對關鍵字作出點擊響應動作。 如圖所示: 解決: 1、使用正則匹配到關鍵字 public static var hashtag = DetectorType.custom(try! NSRegularExpression ...
  • 演示圖 考慮2個情況 一種情況初始狀態下 滾動到在中間區域的時候,這時上半部分看不見的元素就不給字體添加紅色 一種情況是,從頭向下看的. CSS代碼 ...
  • 初學React Native,如果沒有人指引,會發現好多東西無從下手,但當有人指引後,會發現其實很簡單。這也是本人寫這篇博客的主要原因,希望能幫到初學者。 本文不會介紹如何搭建開發環境,如果你還沒有搭建,可參考這裡的官方文檔:https://react-native.org/doc/getting- ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...