Bene ... Ho trovato alcuni problemi in ogni soluzione proposta qui.
- Si dovrebbe essere in grado di scegliere se intero elemento di essere sullo schermo o solo una parte di esso
- soluzioni proposte non riesce se elemento è più alta/più larga finestra e un pò copre la finestra del browser.
Qui è la mia soluzione che includono jQuery
.fn
funzione di istanza e expression
. Ho creato più variabili all'interno della mia funzione di quanto avrei potuto, ma per problemi logici complessi mi piace dividerlo in parti più piccole e chiaramente denominate.
sto usando getBoundingClientRect
metodo che restituisce posizione elemento relativamente alla finestra quindi non ho bisogno di preoccuparsi posizione di scorrimento
Usage:
$(".some-element").filter(":onscreen").doSomething();
$(".some-element").filter(":entireonscreen").doSomething();
$(".some-element").isOnScreen(); // true/false
$(".some-element").isOnScreen(true); // true/false (partially on screen)
$(".some-element").is(":onscreen"); // true/false (partially on screen)
$(".some-element").is(":entireonscreen"); // true/false
Fonte:
$.fn.isOnScreen = function(partial){
//let's be sure we're checking only one element (in case function is called on set)
var t = $(this).first();
//we're using getBoundingClientRect to get position of element relative to viewport
//so we dont need to care about scroll position
var box = t[0].getBoundingClientRect();
//let's save window size
var win = {
h : $(window).height(),
w : $(window).width()
};
//now we check against edges of element
//firstly we check one axis
//for example we check if left edge of element is between left and right edge of scree (still might be above/below)
var topEdgeInRange = box.top >= 0 && box.top <= win.h;
var bottomEdgeInRange = box.bottom >= 0 && box.bottom <= win.h;
var leftEdgeInRange = box.left >= 0 && box.left <= win.w;
var rightEdgeInRange = box.right >= 0 && box.right <= win.w;
//here we check if element is bigger then window and 'covers' the screen in given axis
var coverScreenHorizontally = box.left <= 0 && box.right >= win.w;
var coverScreenVertically = box.top <= 0 && box.bottom >= win.h;
//now we check 2nd axis
var topEdgeInScreen = topEdgeInRange && (leftEdgeInRange || rightEdgeInRange || coverScreenHorizontally);
var bottomEdgeInScreen = bottomEdgeInRange && (leftEdgeInRange || rightEdgeInRange || coverScreenHorizontally);
var leftEdgeInScreen = leftEdgeInRange && (topEdgeInRange || bottomEdgeInRange || coverScreenVertically);
var rightEdgeInScreen = rightEdgeInRange && (topEdgeInRange || bottomEdgeInRange || coverScreenVertically);
//now knowing presence of each edge on screen, we check if element is partially or entirely present on screen
var isPartiallyOnScreen = topEdgeInScreen || bottomEdgeInScreen || leftEdgeInScreen || rightEdgeInScreen;
var isEntirelyOnScreen = topEdgeInScreen && bottomEdgeInScreen && leftEdgeInScreen && rightEdgeInScreen;
return partial ? isPartiallyOnScreen : isEntirelyOnScreen;
};
$.expr.filters.onscreen = function(elem) {
return $(elem).isOnScreen(true);
};
$.expr.filters.entireonscreen = function(elem) {
return $(elem).isOnScreen(true);
};
ho dato una risposta a questa e su questa questione 'duplicato': http://stackoverflow.com/ domande/5353934/check-if-element-is-visible-on-screen/5354536 # 5354536 – Tokimon