br 8eb34


search

Увеличение картинки при наведении

uvelichС помощью скриптов Javascript можно делать самые различные преобразования как для контента, так и для изменений функциональных задач. Так например в данной статье будет описано как сделать плавное увеличение картинки при наведении. Данные изменения можно проэкспериментировать прямо на своём компьютере без подключения к хостингу.

Для начала нужно создать все необходимые файлы: основной файл HTML, файл стилей и документ в формате js, где будет располагаться нужны скрипт.

В данном случае скрипт имеет код:

if (document.images){
(function(){
var cos, a = /Apple/.test(navigator.vendor), times = a? 20 : 40, speed = a? 40 : 20;
var expConIm = function(im){
im = im || window.event;
if (!expConIm.r.test (im.className))
im = im.target || im.srcElement || null;
if (!im || !expConIm.r.test (im.className))
return;
var e = expConIm,
widthHeight = function(dim){
return dim[0] * cos + dim[1] + 'px';
},
resize = function(){
cos = (1 - Math.cos((e.ims[i].jump / times) * Math.PI)) / 2;
im.style.width = widthHeight (e.ims[i].w);
im.style.height = widthHeight (e.ims[i].h);
if (e.ims[i].d && times > e.ims[i].jump){
++e.ims[i].jump;
e.ims[i].timer = setTimeout(resize, speed);
} else if (!e.ims[i].d && e.ims[i].jump > 0){
--e.ims[i].jump;
e.ims[i].timer = setTimeout(resize, speed);
}
}, d = document.images, i = d.length - 1;
for (i; i > -1; --i)
if(d[i] == im) break;
i = i + im.src;
if (!e.ims[i]){
e.ims[i] = {im : new Image(), jump : 0};
e.ims[i].im.onload = function(){
e.ims[i].w = [e.ims[i].im.width - im.width, im.width];
e.ims[i].h = [e.ims[i].im.height - im.height, im.height];
e (im);
};
e.ims[i].im.src = im.src;
return;
}
if (e.ims[i].timer) clearTimeout(e.ims[i].timer);
e.ims[i].d = !e.ims[i].d;
resize ();
};
expConIm.ims = {};
expConIm.r = new RegExp('\\bexpando\\b');
if (document.addEventListener){
document.addEventListener('mouseover', expConIm, false);
document.addEventListener('mouseout', expConIm, false);
}
else if (document.attachEvent){
document.attachEvent('onmouseover', expConIm);
document.attachEvent('onmouseout', expConIm);
}
})();
}

В файле стилей CSS, формат которого .css написать следующее: 

img.expando{
border: none;
vertical-align: bottom;
}

В файле HTML указать путь к файлам CSS и JavaScript :

<link rel="stylesheet" href="/imagesize.css" type="text/css" />
<script type="text/javascript" src="/imagesize.js"></script>
<div>
<img border="0" src="/ИМЯ РИСУНКА.jpg" width="150" height="110">
</div>

Указывая подобный путь, как в примере, данные файлы должны находиться на том же уровне, что и основной файл в формате .html.

Дополнительным плюсом использования скриптов javascript на страницах вашего сайта является, то что все современные модели мобильных телефонов поддерживают их, в отличие от технологие Flash. Поэтому разработчики предпочитают именно javascript.

Добавить комментарий

Защитный код
Обновить

Комментарии