Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 11.02.2017, 12:37
Интересующийся
Отправить личное сообщение для An1984tonn Посмотреть профиль Найти все сообщения от An1984tonn
 
Регистрация: 30.11.2016
Сообщений: 26

Как сделать плавающий фиксированный блок див на js?
Подскажите пожалуйста, как сделать плавающий фиксированный блок на javascript, как тут https://pozvonim.com/?i=3018635123 в нижнем правом углу "заказать звонок".
Интересует его перемещение и возврат к нижнему углу с задержкой
Желательно без jquery если можно))
нашел вот такой пример но не пойму как прижать блок именно к нижнему углу, да и не хотелось подключать здоровенную библиотеку jquery, дабы не перегружать сайт
<style>#scroll{
		position:absolute;
		width:80px;
		height: 80px;
		background: #000;
		left: 85%
		}
		
		body{
			height: 3000px;
		}
	</style>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>	
</head>
<body>
<div id="scroll">
<div id="good"></div>
</div>	


<script>
	
		(function($){
	    $.fn.stickyScroll = function(options) {
	        var defaults = {  
	            easing: 'linear',
	            duration: 300,
	            queue: false
	        }, $t = this;
	        options = $.extend(defaults, options);
	        this.css({ position: 'relative', top: 0 });
	        $(window).scroll(function() {
	            var wst = $(window).scrollTop();
	            $t.each(function() {
	                var getObject = $(this), parent = getObject.parent()
	                if(wst > (parent.offset().top) &&
	                    (parent.height() + parent.position().top - 20) > (wst + getObject.height())
	                ){
	                    getObject.animate({ top: (wst - parent.offset().top) + "px" }, 
	                        { queue: options.queue, easing: options.easing, duration: options.duration });
	                } else if(wst < (parent.offset().top)){
	                    getObject.animate({ top: "0px" },
	                        { queue: options.queue, easing: options.easing, duration: options.duration });
	                }
	            });
	        });
	        return this;
	    };
	})(jQuery);
	</script>
<script type="text/javascript">
	jQuery(function() {
		jQuery('#scroll').stickyScroll();
	});	
</script>

Ответить с цитированием
  #2 (permalink)  
Старый 16.02.2017, 12:46
Интересующийся
Отправить личное сообщение для AndreyAndrey Посмотреть профиль Найти все сообщения от AndreyAndrey
 
Регистрация: 16.02.2017
Сообщений: 10

Это скорее вопрос по CSS.
Пробуй связку:
position: absolute;
left: 0;
bottom: 0;
Ответить с цитированием
  #3 (permalink)  
Старый 16.02.2017, 14:16
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

плавающий фиксированный блок див на js
An1984tonn,

<!DOCTYPE html>

<html>
<head>
  <title>Untitled</title>
  <meta charset="utf-8">
  <style type="text/css">
    #scroll{
    position:absolute;
    width:80px;
    height: 80px;
    background: #000;
    left: 85%;
    transition: top .8s ease-in-out;
    top : 20px;
    }
     .red{
       border: rgb(255, 0, 0) 5px solid;
       border-radius: 50%;
     }

    body{
      position: relative;
      height: 3000px;
    }
  </style>
  <script>
window.addEventListener('DOMContentLoaded', function() {
  var block = document.querySelector('#scroll'),
  top,
  bottom = 50,
  timer;
  document.addEventListener('scroll', function() {
  window.clearTimeout(timer);
  timer = window.setTimeout(function() {
  top = window.pageYOffset + document.documentElement.clientHeight - bottom - block.clientHeight;
  top = window.pageYOffset < 50 ? ''  : top + 'px';
  block.classList.remove('red');
  block.style.top = top;

},80)
  block.addEventListener('transitionend', function() {
  block.classList.add('red')
}, false);
  });
    });
  </script>
</head>

<body>
<div id="scroll" class="red"></div>

</body>
</html>
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как сделать уПирающийся блок ? DENERIK Общие вопросы Javascript 3 25.11.2015 22:06
Как сделать что бы картинки с другого url отображались как свои zlodey Серверные языки и технологии 1 04.05.2015 21:30
Как проверить сайт клиента на установленный блок Alexmad Серверные языки и технологии 10 02.04.2015 20:03
Как сделать акардеон в которому выезжающий блок можно было закрыть! olehpdatu jQuery 3 06.04.2013 17:28
Как сделать блок кнопкой Vladislav Общие вопросы Javascript 2 23.02.2013 16:47