Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 08.03.2013, 14:10
Новичок на форуме
Отправить личное сообщение для mishanay Посмотреть профиль Найти все сообщения от mishanay
 
Регистрация: 14.01.2012
Сообщений: 9

Как это делается?
Подскажите пожалуйста каким скриптом и какой библиотекой реализуется данный эфект?

http://pizza2dom.ru/pizza

При наведении на карточку товара рисуются линии бордера.
Ответить с цитированием
  #2 (permalink)  
Старый 09.03.2013, 00:18
без статуса
Отправить личное сообщение для Deff Посмотреть профиль Найти все сообщения от Deff
 
Регистрация: 25.05.2012
Сообщений: 8,219

mishanay,
В данном случае, div, установленный с positon:absolute за картинкой и увеличивающийся в размере при наведении,
div(ов) два на одну карточку, - установленны по диагонали,
окрас бордеров у этих div только c двух прилегающих сторон
Оба div в общем обрамлении - третьим

Последний раз редактировалось Deff, 09.03.2013 в 00:20.
Ответить с цитированием
  #3 (permalink)  
Старый 09.03.2013, 11:31
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,228

Что-то не пойму почему происходит смена событий при движении мыши "по" диву box...

<!DOCTYPE html>
<html>
<head>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<!--
<link rel="stylesheet" type="text/css" href="tmp.css" />
-->
<style type="text/css">
.box {
	position: relative;
	background-color: #ffffff;
}
.border {
	position: absolute;
	width: 0;
	height: 0;
}
.up {
	top: 0;
	right: 0;
	border-top: 2px solid #ffffff;
	border-right: 2px solid #ffffff;
}
.dn {
	left: 0;
	bottom: 0;
	border-left: 2px solid #ffffff;
	border-bottom: 2px solid #ffffff;
}
</style>
<script type="text/javascript">
$(document).ready(function (){
	$('.box').mouseover(function (){
		var o=$('.border');
		o.css({
			borderColor: 'green',
		});
		o.animate({
			width: '50%',
			height: '50%'
		});
	});
	$('.box').mouseout(function (){
		var o=$('.border');
		o.animate({
			width: 0,
			height: 0
		});
		o.css({
			borderColor: '#ffffff',
		});
	});
});
</script>
</head>
<body>
<div class='box'>
	<div class='border up'></div>
	<div class='border dn'></div>
	<img src='http://pizza2dom.ru/image/cache/data/pizza/margarita-250x250.jpg' />
</div>
</body>
</html>
Ответить с цитированием
  #4 (permalink)  
Старый 09.03.2013, 20:22
Новичок на форуме
Отправить личное сообщение для mishanay Посмотреть профиль Найти все сообщения от mishanay
 
Регистрация: 14.01.2012
Сообщений: 9

Я могу только предположить что анимация зацикливается и ее надо остановить после первого воспроизведения
Ответить с цитированием
  #5 (permalink)  
Старый 10.03.2013, 11:01
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,228

Сообщение от mishanay
анимация зацикливается
Нет.
Почему-то события mouseout и mouseover mouseout срабатывают при движении по ДИВу...

<!DOCTYPE html>
<html>
<head>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<!--
<link rel="stylesheet" type="text/css" href="tmp.css" />
-->
<style type="text/css">
.box {
	position: relative;
	background-color: #ffffff;
}
.border {
	position: absolute;
	width: 0;
	height: 0;
}
.up {
	top: 0;
	right: 0;
	border-top: 2px solid #ffffff;
	border-right: 2px solid #ffffff;
}
.dn {
	left: 0;
	bottom: 0;
	border-left: 2px solid #ffffff;
	border-bottom: 2px solid #ffffff;
}
</style>
<script type="text/javascript">
$(document).ready(function (){
	$('.box').mouseover(function (){
		alert(1);
		var o=$('.border');
		o.css({
			borderColor: 'green',
		});
		o.animate({
			width: '50%',
			height: '50%'
		});
	});
	$('.box').mouseout(function (){
		alert(2);
		var o=$('.border');
		o.animate({
			width: 0,
			height: 0
		});
		o.css({
			borderColor: '#ffffff',
		});
	});
});
</script>
</head>
<body>
<div class='box'>
	<div class='border up'></div>
	<div class='border dn'></div>
	<img src='http://pizza2dom.ru/image/cache/data/pizza/margarita-250x250.jpg' />
</div>
</body>
</html>
Ответить с цитированием
  #6 (permalink)  
Старый 10.03.2013, 13:43
Новичок на форуме
Отправить личное сообщение для mishanay Посмотреть профиль Найти все сообщения от mishanay
 
Регистрация: 14.01.2012
Сообщений: 9

Да это действительно странно! Где уважаемые знатоки? Помогите разобраться!
Ответить с цитированием
  #7 (permalink)  
Старый 10.03.2013, 16:55
х.з
Посмотреть профиль Найти все сообщения от dmitriymar
 
Регистрация: 21.11.2010
Сообщений: 4,588

Сообщение от mishanay
Да это действительно странно! Где уважаемые знатоки? Помогите разобраться!
что здесь странного? это стандартное поведение out и over при преходе на дочерний срабатывает событие out родителя и т.д
используйте события leave и enter http://jquery-docs.ru/events/mouseleave/
Ответить с цитированием
  #8 (permalink)  
Старый 10.03.2013, 18:36
без статуса
Отправить личное сообщение для Deff Посмотреть профиль Найти все сообщения от Deff
 
Регистрация: 25.05.2012
Сообщений: 8,219

<!DOCTYPE html>
<html>
<head>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<!--
<link rel="stylesheet" type="text/css" href="tmp.css" />
-->
<style type="text/css">
.box {
	position: relative;
	background-color: #ffffff;
}
.border {
	position: absolute;
	width: 0;
	height: 0;
}
.up {
	top: 0;
	right: 0;
	border-top: 1px solid #ffffff;
	border-right: 1px solid #ffffff;
}
.dn {
	left: 0;
	bottom: 0;
	border-left: 1px solid #ffffff;
	border-bottom: 1px solid #ffffff;
}
</style>
<script type="text/javascript">
$(document).ready(function (){
	$('.box').mouseover(function (){
		var o=$('.border');
		o.css({
			borderColor: 'green',
		});
		o.stop().animate({
			width: '50%',
			height: '50%'
		},600);
	});
	$('.box').mouseout(function (){
		var o=$('.border');
		o.stop().animate({
			width: 0,
			height: 0
		},400, "linear", function (){
		o.css({
			borderColor: '#fff',
		});
});

	});
});
</script>
</head>
<body>
<div class='box'>
	<div class='border up'></div>
	<div class='border dn'></div>
	<img src='http://pizza2dom.ru/image/cache/data/pizza/margarita-250x250.jpg' />
</div>
</body>
</html>

Последний раз редактировалось Deff, 10.03.2013 в 19:11.
Ответить с цитированием
  #9 (permalink)  
Старый 10.03.2013, 18:54
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,228

Сообщение от dmitriymar
это стандартное поведение out и over при преходе на дочерний срабатывает событие out родителя и т.д
Но :hover таким не страдает...

Причем "моргание" происходит даже если не двигать по картинке, а например в правой стороне ДИВа...
Ответить с цитированием
  #10 (permalink)  
Старый 10.03.2013, 18:59
без статуса
Отправить личное сообщение для Deff Посмотреть профиль Найти все сообщения от Deff
 
Регистрация: 25.05.2012
Сообщений: 8,219

Сообщение от ksa
Причем "моргание" происходит даже если не двигать по картинке, а например в правой стороне ДИВа...
ksa,
Во фрейме, события over для javascrip прерываются еще и таймированием, к примеру с родительской, нун не в топике тестить
Ответить с цитированием
Ответ



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

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


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как бы Вы это верстали? madd1 (X)HTML/CSS 19 03.08.2012 00:13
как это понять? Arkinsstoun jQuery 2 20.01.2012 18:44
Как это реализовать ~online~ Оффтопик 9 13.07.2010 16:15
1092*0.15=? А на javascript? Как это объяснить бухгатеру? oid Общие вопросы Javascript 15 24.10.2009 12:51
Как это сделать? PAMAC Общие вопросы Javascript 2 10.10.2009 21:02