10 вставок кода jQuery
jQuery вдохнул новую жизнь в JavaScript. В данном уроке приводится 10 вставок кода jQuery, которые облегчат решение повседневных задач, возникающих при создании веб приложений.
Предварительная загрузка изображений
Предварительная загрузка изображений очень полезна, ведь картинки будут загружаться, пока пользователь занят просмотром другого материала. С помощью jQuery задача решается очень просто:
Code
(function($) {
var cache = [];
// Аргументом является путь к изображению, относительно текущей страницы
$.preLoadImages = function() {
var args_len = arguments.length;
for (var i = args_len; i--;) {
var cacheImage = document.createElement('img');
cacheImage.src = arguments[i];
cache.push(cacheImage);
}
}
jQuery.preLoadImages("image1.gif", "/path/to/image2.png");
var cache = [];
// Аргументом является путь к изображению, относительно текущей страницы
$.preLoadImages = function() {
var args_len = arguments.length;
for (var i = args_len; i--;) {
var cacheImage = document.createElement('img');
cacheImage.src = arguments[i];
cache.push(cacheImage);
}
}
jQuery.preLoadImages("image1.gif", "/path/to/image2.png");
Снабжаем ссылки атрибутом target=”blank”
Следующий код будет открывать все ссылки, снабженные атрибутом rel="external" в новой закладке или окне. Код легко модифицировать для открытия ссылок только с определенным классом.
Code
$('a[@rel$='external']').click(function(){
this.target = "_blank";
});
/*
Использование:
<a href="http://get-element.3dn.ru" rel="external">http://get-element.3dn.ru</a>
*/
this.target = "_blank";
});
/*
Использование:
<a href="http://get-element.3dn.ru" rel="external">http://get-element.3dn.ru</a>
*/
Добавляем класс к тегу если разрешен JavaScript
Данный код представляет собой всего одну строку. Но это самый простой способ определить разрешение использования JavaScript в браузере клиента. Если разрешение есть, класс hasJS будет добавлен к тегу .
Code
$('body').addClass('hasJS');
Плавная прокрутка для ссылки
jQuery известен своим функционалом для создания визуальных эффектов. Простой, но приятный эффект - плавное проскальзывание содержания до ссылки. Следующий код создает такой эффект,когда нажимается ссылка с классом topLink.
Code
$(document).ready(function() {
$("a.topLink").click(function() {
$("html, body").animate({
scrollTop: $($(this).attr("href")).offset().top + "px"
}, {
duration: 500,
easing: "swing"
});
return false;
});
});
$("a.topLink").click(function() {
$("html, body").animate({
scrollTop: $($(this).attr("href")).offset().top + "px"
}, {
duration: 500,
easing: "swing"
});
return false;
});
});
Плавное проявление/затухание при наведении курсора мыши
Еще один приятный визуальный эффект, который очень популярен - плавное проявление/затухание элементов при наведении на них курсора мыши. Следующий код устанавливает непрозрачность 100% при наведении курсора мыши, и 60% - при потере фокуса.
Code
$(document).ready(function(){
$(".thumbs img").fadeTo("slow", 0.6); // Устанавливаем непрозрачность миниатюр до 60% при загрузке страницы.
$(".thumbs img").hover(function(){
$(this).fadeTo("slow", 1.0); // При наведении курсора, непрозрачность становится 100%.
},function(){
$(this).fadeTo("slow", 0.6); // Пр потере фокуса непрозрачность опять становится 60%.
});
});
$(".thumbs img").fadeTo("slow", 0.6); // Устанавливаем непрозрачность миниатюр до 60% при загрузке страницы.
$(".thumbs img").hover(function(){
$(this).fadeTo("slow", 1.0); // При наведении курсора, непрозрачность становится 100%.
},function(){
$(this).fadeTo("slow", 0.6); // Пр потере фокуса непрозрачность опять становится 60%.
});
});
Равная высота колонок
При построении шаблона с использованием колонок очень хочется, чтобы они были одинаковой высоты, как в старой доброй таблице. Ниже приведенный код автоматически вычисляет самую высокую колонку и выравнивает остальные по ней.
Code
var max_height = 0;
$("div.col").each(function(){
if ($(this).height() > max_height) { max_height = $(this).height(); }
});
$("div.col").height(max_height);
$("div.col").each(function(){
if ($(this).height() > max_height) { max_height = $(this).height(); }
});
$("div.col").height(max_height);
Enable HTML5 markup on older browsers
HTML5 определенно представляет собой будущее веб разработки клиентский приложений. К сожалению, старые браузеры не распознают новых тегов, таких как header или section. Данный код принуждает старые браузеры распознавать новые теги HTML5.
Лучшим вариантом решения будет присоединять файл .js в раздел вашей страницы HTML:
Code
<!--[if lt IE 9]>
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
Проверяем поддержку браузером определенных свойств CSS3
Здесь приводится простая функция jQuery для проверки поддержки браузером клиента определенных свойств CSS3. В данном примере проверяется свойство border-radius, но код можно легко модифицировать для проверки другого свойства.
Примечание: нужно опускать тире при передаче имени свойства в качестве парметра. Например, вместо border-radius, нужно вводить "borderRadius” или "BorderRadius”.
Code
var supports = (function() {
var div = document.createElement('div'),
vendors = 'Khtml Ms O Moz Webkit'.split(' '),
len = vendors.length;
return function(prop) {
if ( prop in div.style ) return true;
prop = prop.replace(/^[a-z]/, function(val) {
return val.toUpperCase();
});
while(len--) {
if ( vendors[len] + prop in div.style ) {
// Браузер поддерживает свойство.
// Или можно использовать оператор отрицания (!).
return true;
}
}
return false;
};
})();
if ( supports('borderRadius') ) {
document.documentElement.className += ' borderRadius';
var div = document.createElement('div'),
vendors = 'Khtml Ms O Moz Webkit'.split(' '),
len = vendors.length;
return function(prop) {
if ( prop in div.style ) return true;
prop = prop.replace(/^[a-z]/, function(val) {
return val.toUpperCase();
});
while(len--) {
if ( vendors[len] + prop in div.style ) {
// Браузер поддерживает свойство.
// Или можно использовать оператор отрицания (!).
return true;
}
}
return false;
};
})();
if ( supports('borderRadius') ) {
document.documentElement.className += ' borderRadius';
Получаем параметры URL
Получение параметров URL с помощью jQuery - очень простой процесс.
Code
$.urlParam = function(name){
var results = new RegExp('[\\?&]' + name + '=([^&#]*)').exec(window.location.href);
if (!results) { return 0; }
return results[1] || 0;
}
var results = new RegExp('[\\?&]' + name + '=([^&#]*)').exec(window.location.href);
if (!results) { return 0; }
return results[1] || 0;
}
Отключаем клавишу "Enter” в формах
По умолчанию, форма может быть отправлена нажатием клавиши "Enter”. Но в некоторых формах такой функционал может оказаться лишним и порождать некоторые проблемы при вводе данных. Ниже приведенный код подавляет функционирование клавиши "Enter” в форме.
Code
$("#form").keypress(function(e) {
if (e.which == 13) {
return false;
}
});
if (e.which == 13) {
return false;
}
});
-
FalleN -
1313 -
1 -
0
Но только нужно ставить наверное на те модули которые обновляться должны не раньше через пару тройку минут
С Уважением, Андрей...