I'm feeling a bit lost on this one. Is there a trick to causing a div to transition from display:none (or something comparable) once a specific div on the page has been scrolled beyond?
I'm feeling a bit lost on this one. Is there a trick to causing a div to transition from display:none (or something comparable) once a specific div on the page has been scrolled beyond?
To start, assign an ID to your div
, such as dvid
. Then, assume the other div
(the one you want to detect scrolling after) has the ID othdiv
.
You can then try this code snippet:
$(document).ready( function() {
$("#dvid").hide(); //begin by hiding your div
var topOfOthDiv = $("#othdiv").offset().top;
$(window).scroll(function() {
if($(window).scrollTop() > topOfOthDiv) { //have you scrolled past the other div?
$("#dvid").show(); //once you reach the specified point, show the div
}
});
});
Check out a small jsFiddle demonstration here: link to demo.
To trigger a function when the window is scrolled, you can retrieve the current scroll position and the distance of a specific element from the top of the page. Based on this information, you can choose to show or hide your desired element dynamically.
window.onscroll = function (oEvent) {
var mydivpos = document.getElementById("mydiv").offsetTop;
var scrollPos = document.getElementsByTagName("body")[0].scrollTop;
if(scrollPos >= mydivpos)
document.getElementById("noshow").className = "";
else
document.getElementById("noshow").className = "hidden";
};
SCROLLBAR FUNCTIONALITY AND WINDOW SCROLL POSITION
In my exploration, I have found that utilizing functions like the one mentioned above, (there are numerous similar examples on this platform - all proven to be effective), only works effectively when scrollbars are visible and in use.
If you attempt to implement such functionality while aiming for a minimalist design with no scrollbars, like the concept discussed at this thread, then using $(window).scrollTop() will not yield the desired outcome.
While this may seem like a basic programming principle, I wanted to share this insight with fellow beginners, as it took me some time to realize this limitation.
If anyone has suggestions on overcoming this challenge or further insights to share, please feel free to respond. I had to resort to alternate methods like show/hide onmouseover/mouseleave as seen here
May your programming journey be long and prosperous, CollyG.
Check out this functioning demo.
The script uses jQuery to monitor scrolling and show or hide a hidden element based on the scroll position:
$(function(){
var hiddenElement = $('.hidden');
var topPosition = hiddenElement.offset().top;
var windowObj = $(window);
windowObj.scroll(function(){
var scrollTopPos = windowObj.scrollTop();
if(scrollTopPos >= topPosition){
hiddenElement.show(2000);
} else {
hiddenElement.hide(2000);
}
});
});
Adapted from @Abody97's solution to reveal a div after it has been scrolled past
http://jsfiddle.net/nickaknudson/f72vg/
$(document).ready( function() {
$("#div_to_show").hide(); //initially hide the targeted div
$(window).scroll(function() {
// reveal when top of div is passed while scrolling
if($(body).scrollTop() >= $("#div_to_scroll_past").offset().top) {
$("#div_to_show").show(); //display the div once desired point is reached
}
});
});
OR reveal when the bottom of the div is scrolled beyond
$(document).ready( function() {
$("#div_to_show").hide(); //initially hide the targeted div
$(window).scroll(function() {
// reveal when bottom of div is scrolled past
if($(body).scrollTop() >= ( $("#div_to_scroll_past").offset().top + $("#div_to_scroll_past").outerHeight() )) {
$("#div_to_show").show(); //display the div once desired point is reached
}
});
});
ADDITIONAL INFORMATION
To achieve this, an effective approach would involve utilizing jQuery along with a function resembling the following.
var scrollPosition = 750; // Specify the vertical position at which the event triggers.
$(window).scroll(function(e) {
if (window.pageYOffset >= scrollPosition) {
triggerEvent();
}
});
function triggerEvent() {
// Implement the necessary logic to accomplish your objective here.
};
Is there a way to adjust the position of the "Next" button when a certain div is not visible on the page? I want the button to come at the place of the hidden div. <div ng-show="(currentQuoteQto.requestType===constants.ssoQuote || currentQuoteQto.bu ...
I am facing a challenge with my AngularJS dropdown that uses ng-options. I want to apply both the filter and orderBy components together in the ng-options section. The filter for the select is functioning correctly, but it seems like the OrderBy component ...
Looking to implement a unique two-level radio button feature for a specific option only. Currently, I have written a logic that will display additional radio buttons under the 'Spring' option. However, the issue is that when it's selected, t ...
Is it possible to integrate my website with an iOS device and utilize the device's camera functionality? After capturing an image, the camera returns it in a base64 image format. Is there a way to convert this to a file type? If the mobile device pr ...
Within my MongoDB database, I have a collection of bets structured like this: { id: String, user_id: String, type: String, events: [{ eventID: String, sport: String, evento: String, ...
I am attempting to pass a variable value from HTML to Angular. Here is an example of what I am trying to achieve: <span (click)="toggle()" toggled="true" class="glyphicon glyphicon-unchecked"></span>> And in the controller: @Input() toggl ...
I encountered a strange issue with a TypeScript condition in a function. Here is my current code, where the parameters are passed from outside: getLevel(validation: string, status: string): string { let card = ""; if (validation == &qu ...
Utilizing jQuery $.ajax json POST, I am accessing my WCF Web service. One of the input parameters is notably lengthy - exceeding 8000 bytes. It comprises a list of GUIDs separated by commas, such as "78dace54-1eea-4b31-8a43-dcd01e172d14,ce485e64-e7c6-4 ...
I am currently working on a website where I am trying to implement an accordion menu on elements that have been styled with Cufon. Unfortunately, the accordion menu is not functioning properly on these elements. It seems like the issue arises because of ...
It has been quite some time that I have been attempting to find a way to automatically accept SSL certificates. Unfortunately, I haven't had any success yet. The scenario is this: I am working on selenium tests and every time I run the test on Chrome, ...
I am facing an issue in my Angular2 application where I am trying to display an image in Uint8Array format. The problem arises when the image size exceeds ~300Kb, resulting in a 'Maximum Call Stack Exceeded' error. Currently, I have been able to ...
I'm experiencing difficulty generating the PDF report from this JSP page. While I can create the form in a .pdf format, it's not opening correctly in Adobe Reader. <% //response.setCharacterEncoding("utf-8"); //response.setHeader("Content-Tr ...
I have constructed a carousel using HTML, but for some reason it does not display anything once compiled. <div class="list-offers"> <div class="container"> <div class="row1"> <div class="col-xs-12 item bg_fix right" style="ba ...
I'm trying to figure out how to use jQuery ajax to redirect to the next page. I'm new to jQuery and ajax, so I'm struggling with the syntax. Any help would be greatly appreciated. I've searched for information on this topic, but nothin ...
I am currently developing an inline editing feature, and I would like to display a green checkmark in a column cell to indicate that the record has been updated. However, I need to hide it initially. This is how it looks at the moment: https://i.sstatic. ...
I'm currently working on developing a responsive chatbot using CSS Bootstrap. However, I've encountered an issue where the header and footer are not fixed when I open the app on an iPhone. The keyboard header is also moving up the screen, which s ...
I am struggling to get a tooltip to properly display on top of its parent element. Despite trying various combinations of z-index and overflow properties, I have not been able to achieve the desired outcome. The issue arises when hovering over the red box ...
My application.scss file in SASS is causing unexpected CSS changes on the production server, particularly affecting my a:hover Here is a snippet from my application.css: pre { background-color: #eee; padding: 10px; font-size: 11px; } a { color ...
Description: I am incorporating ui-router to load form pages upon clicking an icon. Every time the user clicks on the icon, a new form should load with all fields reset. By adding ng-click to the icon, we can easily reset the form values. index.html &l ...
My web application is created using Bootstrap and Flask and it loads a Bokeh server document into a container div. The responsiveness of the Bokeh elements' size depends on a specific fixed initial height set for the containing div. This customization ...