jQuery | Keep top div element in view while window scrolling
I have a div element with class .b-widget
and is present on the top of the page.
When I scroll down
, the div goes away and when I scroll up
it appears again.
I want it to stick to its place when i scroll down
and resume when I scroll up
.
I wrote below script
but this is not helping either :
<script>
//keep element in view
(function($)
{
$(document).ready( function()
{
var elementPosTop = $('.b-widget').position().top;
$(window).scroll(function()
{
var wintop = $(window).scrollTop(), docheight = $(document).height(), winheight = $(window).height();
//if top of element is in view
if (wintop > elementPosTop)
{
//always in view
$('.b-widget').css({ "position":"fixed", "top":"50px" });
}
else
{
//reset back to normal viewing
$('.b-widget').css({ "position":"inherit" });
}
});
});
})(jQuery);
</script>
javascript jquery
|
show 2 more comments
I have a div element with class .b-widget
and is present on the top of the page.
When I scroll down
, the div goes away and when I scroll up
it appears again.
I want it to stick to its place when i scroll down
and resume when I scroll up
.
I wrote below script
but this is not helping either :
<script>
//keep element in view
(function($)
{
$(document).ready( function()
{
var elementPosTop = $('.b-widget').position().top;
$(window).scroll(function()
{
var wintop = $(window).scrollTop(), docheight = $(document).height(), winheight = $(window).height();
//if top of element is in view
if (wintop > elementPosTop)
{
//always in view
$('.b-widget').css({ "position":"fixed", "top":"50px" });
}
else
{
//reset back to normal viewing
$('.b-widget').css({ "position":"inherit" });
}
});
});
})(jQuery);
</script>
javascript jquery
1
it's not exactly clear what is wrong with your code, just looks like you would have an extra 50px top when you reset it. I would use a class to make it fixed instead of using css directly on your element - that way you do not have to reset all your css back to normal, you can just remove the class that fixes it - see this jsfiddle.net/FyEGN/2
– Pete
Nov 19 '18 at 10:38
1
Or this would be closer to what you are after: jsfiddle.net/FyEGN/1515
– Pete
Nov 19 '18 at 10:46
why you do not fixed it for ever in css that take "position":"fixed", "top":"50px"
– LDS
Nov 19 '18 at 11:31
@Pete else part is working but not if part. Her is the code I writtem :
– Ambika Tewari
Nov 20 '18 at 11:29
<style> .fixed {position:fixed; top:0; left:0; z-index:2; width:100%;} </style> <script> $(window).scroll(function(){ if ($(this).scrollTop() > 100) { $(".flight-filters.ow").css({ "display": "none", "opacity": "0" }).fadeOut("slow"); $('.b-widget > .container-fluid').addClass('fixed'); } else { $('.b-widget > .container-fluid').removeClass('fixed'); } }); </script>
– Ambika Tewari
Nov 20 '18 at 11:29
|
show 2 more comments
I have a div element with class .b-widget
and is present on the top of the page.
When I scroll down
, the div goes away and when I scroll up
it appears again.
I want it to stick to its place when i scroll down
and resume when I scroll up
.
I wrote below script
but this is not helping either :
<script>
//keep element in view
(function($)
{
$(document).ready( function()
{
var elementPosTop = $('.b-widget').position().top;
$(window).scroll(function()
{
var wintop = $(window).scrollTop(), docheight = $(document).height(), winheight = $(window).height();
//if top of element is in view
if (wintop > elementPosTop)
{
//always in view
$('.b-widget').css({ "position":"fixed", "top":"50px" });
}
else
{
//reset back to normal viewing
$('.b-widget').css({ "position":"inherit" });
}
});
});
})(jQuery);
</script>
javascript jquery
I have a div element with class .b-widget
and is present on the top of the page.
When I scroll down
, the div goes away and when I scroll up
it appears again.
I want it to stick to its place when i scroll down
and resume when I scroll up
.
I wrote below script
but this is not helping either :
<script>
//keep element in view
(function($)
{
$(document).ready( function()
{
var elementPosTop = $('.b-widget').position().top;
$(window).scroll(function()
{
var wintop = $(window).scrollTop(), docheight = $(document).height(), winheight = $(window).height();
//if top of element is in view
if (wintop > elementPosTop)
{
//always in view
$('.b-widget').css({ "position":"fixed", "top":"50px" });
}
else
{
//reset back to normal viewing
$('.b-widget').css({ "position":"inherit" });
}
});
});
})(jQuery);
</script>
javascript jquery
javascript jquery
asked Nov 19 '18 at 10:33
Ambika TewariAmbika Tewari
1216
1216
1
it's not exactly clear what is wrong with your code, just looks like you would have an extra 50px top when you reset it. I would use a class to make it fixed instead of using css directly on your element - that way you do not have to reset all your css back to normal, you can just remove the class that fixes it - see this jsfiddle.net/FyEGN/2
– Pete
Nov 19 '18 at 10:38
1
Or this would be closer to what you are after: jsfiddle.net/FyEGN/1515
– Pete
Nov 19 '18 at 10:46
why you do not fixed it for ever in css that take "position":"fixed", "top":"50px"
– LDS
Nov 19 '18 at 11:31
@Pete else part is working but not if part. Her is the code I writtem :
– Ambika Tewari
Nov 20 '18 at 11:29
<style> .fixed {position:fixed; top:0; left:0; z-index:2; width:100%;} </style> <script> $(window).scroll(function(){ if ($(this).scrollTop() > 100) { $(".flight-filters.ow").css({ "display": "none", "opacity": "0" }).fadeOut("slow"); $('.b-widget > .container-fluid').addClass('fixed'); } else { $('.b-widget > .container-fluid').removeClass('fixed'); } }); </script>
– Ambika Tewari
Nov 20 '18 at 11:29
|
show 2 more comments
1
it's not exactly clear what is wrong with your code, just looks like you would have an extra 50px top when you reset it. I would use a class to make it fixed instead of using css directly on your element - that way you do not have to reset all your css back to normal, you can just remove the class that fixes it - see this jsfiddle.net/FyEGN/2
– Pete
Nov 19 '18 at 10:38
1
Or this would be closer to what you are after: jsfiddle.net/FyEGN/1515
– Pete
Nov 19 '18 at 10:46
why you do not fixed it for ever in css that take "position":"fixed", "top":"50px"
– LDS
Nov 19 '18 at 11:31
@Pete else part is working but not if part. Her is the code I writtem :
– Ambika Tewari
Nov 20 '18 at 11:29
<style> .fixed {position:fixed; top:0; left:0; z-index:2; width:100%;} </style> <script> $(window).scroll(function(){ if ($(this).scrollTop() > 100) { $(".flight-filters.ow").css({ "display": "none", "opacity": "0" }).fadeOut("slow"); $('.b-widget > .container-fluid').addClass('fixed'); } else { $('.b-widget > .container-fluid').removeClass('fixed'); } }); </script>
– Ambika Tewari
Nov 20 '18 at 11:29
1
1
it's not exactly clear what is wrong with your code, just looks like you would have an extra 50px top when you reset it. I would use a class to make it fixed instead of using css directly on your element - that way you do not have to reset all your css back to normal, you can just remove the class that fixes it - see this jsfiddle.net/FyEGN/2
– Pete
Nov 19 '18 at 10:38
it's not exactly clear what is wrong with your code, just looks like you would have an extra 50px top when you reset it. I would use a class to make it fixed instead of using css directly on your element - that way you do not have to reset all your css back to normal, you can just remove the class that fixes it - see this jsfiddle.net/FyEGN/2
– Pete
Nov 19 '18 at 10:38
1
1
Or this would be closer to what you are after: jsfiddle.net/FyEGN/1515
– Pete
Nov 19 '18 at 10:46
Or this would be closer to what you are after: jsfiddle.net/FyEGN/1515
– Pete
Nov 19 '18 at 10:46
why you do not fixed it for ever in css that take "position":"fixed", "top":"50px"
– LDS
Nov 19 '18 at 11:31
why you do not fixed it for ever in css that take "position":"fixed", "top":"50px"
– LDS
Nov 19 '18 at 11:31
@Pete else part is working but not if part. Her is the code I writtem :
– Ambika Tewari
Nov 20 '18 at 11:29
@Pete else part is working but not if part. Her is the code I writtem :
– Ambika Tewari
Nov 20 '18 at 11:29
<style> .fixed {position:fixed; top:0; left:0; z-index:2; width:100%;} </style> <script> $(window).scroll(function(){ if ($(this).scrollTop() > 100) { $(".flight-filters.ow").css({ "display": "none", "opacity": "0" }).fadeOut("slow"); $('.b-widget > .container-fluid').addClass('fixed'); } else { $('.b-widget > .container-fluid').removeClass('fixed'); } }); </script>
– Ambika Tewari
Nov 20 '18 at 11:29
<style> .fixed {position:fixed; top:0; left:0; z-index:2; width:100%;} </style> <script> $(window).scroll(function(){ if ($(this).scrollTop() > 100) { $(".flight-filters.ow").css({ "display": "none", "opacity": "0" }).fadeOut("slow"); $('.b-widget > .container-fluid').addClass('fixed'); } else { $('.b-widget > .container-fluid').removeClass('fixed'); } }); </script>
– Ambika Tewari
Nov 20 '18 at 11:29
|
show 2 more comments
1 Answer
1
active
oldest
votes
use css like this:
.b-widget{
position: fixed;
width: 100%;
top: 0;
left: 0;
}
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53372705%2fjquery-keep-top-div-element-in-view-while-window-scrolling%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
use css like this:
.b-widget{
position: fixed;
width: 100%;
top: 0;
left: 0;
}
add a comment |
use css like this:
.b-widget{
position: fixed;
width: 100%;
top: 0;
left: 0;
}
add a comment |
use css like this:
.b-widget{
position: fixed;
width: 100%;
top: 0;
left: 0;
}
use css like this:
.b-widget{
position: fixed;
width: 100%;
top: 0;
left: 0;
}
answered Nov 19 '18 at 12:22
shaghayegh sheykholeslamishaghayegh sheykholeslami
1887
1887
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53372705%2fjquery-keep-top-div-element-in-view-while-window-scrolling%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
1
it's not exactly clear what is wrong with your code, just looks like you would have an extra 50px top when you reset it. I would use a class to make it fixed instead of using css directly on your element - that way you do not have to reset all your css back to normal, you can just remove the class that fixes it - see this jsfiddle.net/FyEGN/2
– Pete
Nov 19 '18 at 10:38
1
Or this would be closer to what you are after: jsfiddle.net/FyEGN/1515
– Pete
Nov 19 '18 at 10:46
why you do not fixed it for ever in css that take "position":"fixed", "top":"50px"
– LDS
Nov 19 '18 at 11:31
@Pete else part is working but not if part. Her is the code I writtem :
– Ambika Tewari
Nov 20 '18 at 11:29
<style> .fixed {position:fixed; top:0; left:0; z-index:2; width:100%;} </style> <script> $(window).scroll(function(){ if ($(this).scrollTop() > 100) { $(".flight-filters.ow").css({ "display": "none", "opacity": "0" }).fadeOut("slow"); $('.b-widget > .container-fluid').addClass('fixed'); } else { $('.b-widget > .container-fluid').removeClass('fixed'); } }); </script>
– Ambika Tewari
Nov 20 '18 at 11:29