簡體   English   中英

JavaScript:根據媒體查詢設置滾動位置變量

[英]JavaScript: Set scroll position variable according to media queries

我正在研究Web項目上的淡入/淡出滾動效果。 在我的js上,我必須為滾動位置設置一個特定的值,即要使效果生效的偏移量。

問題:

  • 由於高度不同,偏移值不能應用於所有類型的設備。

問題(分層):

  1. 如何使靜態值動態變化並隨設備高度/媒體查詢而變化?
  2. 一般而言,如何縮減代碼?
  3. 如何從右/左稍微觸發額外的滑動效果?

這是代碼:

    // ---### FOUNDATION FRAMEWORK ###---
$(document).foundation() 

// ---### FADE FX ###---  

// ## SECTION-01: fade out on scroll ##  
$(window).scroll(function(){  
    // fade out content a  
    $(".j-fadeOut").css("opacity", 1 - $(window).scrollTop() / 470);// 470 should be variable  

    // ## SECTION-02: fade in/out on scroll bottom ##  
    var offset = $('.j-fadeOut-2').offset().top;  
    console.log('offset: '+offset);  
    console.log('window: '+$(window).scrollTop())
    if($(window).scrollTop() > offset)  
    {  
      // fade out top part of content b  
        $(".j-fadeOut-2").css("opacity", 1-($(window).scrollTop() - offset)/520);// 520 should be variable

      // fade in bottom part of content c
      $(".j-fadeIn").css("opacity", 0 + ($(window).scrollTop() - offset)/ 1100);// 1100 should be variable
    }
  });

請參閱此處以獲取JavaScript媒體查詢

您可以使用window.matchMedia在JavaScript中執行媒體查詢。 例:

var mediaQuery = window.matchMedia( "(min-width: 800px)" );

結果將作為布爾值存儲在mediaQuery.matches ,即

if (mediaQuery.matches) {
  // window width is at least 800px
} else {
  // window width is less than 800px
}

您可以使用多個以適合您不同的設備寬度。 使用標准的Bootstrap存儲桶:

var sizes = ['1200px', '992px', '768px', '480px']; // standard Bootstrap breakpoints
var fadeOutAs = [470, 500, 530, 560]; // this corresponds to your content a fadeout variable. Modify as required per screen size
var fadeOutBs = [520, 530, 540, 550]; // content B fadeout
var fadeOutCs = [1100, 1200, 1300, 1400]; // content C fadeout

var fadeOutA = 0;
var fadeOutB = 0;
var fadeOutC = 0;

for (i = 0; i < sizes.length; i++) {
    var mediaQuery = window.matchMedia( "(min-width: " + sizes[i] + ")" );
    if (mediaQuery.matches) {
        fadeOutA = fadeOutAs[i];
        fadeOutB = fadeOutBs[i];
        fadeOutC = fadeOutCs[i];
    }
}

希望這可以幫助

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM