10 вставок кода jQuery

jQuery вдохнул новую жизнь в JavaScript. В данном уроке приводится 10 вставок кода jQuery, которые облегчат решение повседневных задач, возникающих при создании веб приложений.

 

Предварительная загрузка изображений

Предварительная загрузка изображений очень полезна, ведь картинки будут загружаться, пока пользователь занят просмотром другого материала. С помощью jQuery задача решается очень просто:

(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");

 

Снабжаем ссылки атрибутом target=”blank”

Следующий код будет открывать все ссылки, снабженные атрибутом rel="external" в новой закладке или окне. Код легко модифицировать для открытия ссылок только с определенным классом.

$('a[@rel$='external']').click(function(){
     this.target = "_blank";
});

/*
   Использование:
   <a href="http://www.ruseller.com" rel="external">ruseller.com</a>
*/

 

Добавляем класс к тегу <body> если разрешен JavaScript

Данный код представляет собой всего одну строку. Но это самый простой способ определить разрешение использования JavaScript в браузере клиента. Если разрешение есть, класс hasJS будет добавлен к тегу <body>.

$('body').addClass('hasJS');

 

Плавная прокрутка для ссылки

jQuery известен своим функционалом для создания визуальных эффектов. Простой, но приятный эффект - плавное проскальзывание содержания до ссылки. Следующий код создает такой эффект, когда нажимается ссылка с классом topLink.

$(document).ready(function() {
	$("a.topLink").click(function() {
		$("html, body").animate({
			scrollTop: $($(this).attr("href")).offset().top + "px"
		}, {
			duration: 500,
			easing: "swing"
		});
		return false;
	});
});

 

Плавное проявление/затухание при наведении курсора мыши

Еще один приятный визуальный эффект, который очень популярен - плавное проявление/затухание элементов при наведении на них курсора мыши. Следующий код устанавливает непрозрачность 100% при наведении курсора мыши, и 60% - при потере фокуса.

$(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%.
    });
});

 

Равная высота колонок

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

var max_height = 0;
$("div.col").each(function(){
    if ($(this).height() > max_height) { max_height = $(this).height(); }
});
$("div.col").height(max_height);

 

Поддержка HTML5 в устаревших браузерах

HTML5 определенно представляет собой будущее веб разработки клиентский приложений. К сожалению, старые браузеры не распознают новых тегов, таких как header или section. Данный код принуждает старые браузеры распознавать новые теги HTML5.

(function(){if(!/*@cc_on!@*/0)return;var e = "abbr,article,aside,audio,bb,canvas,datagrid,datalist,details,dialog,eventsource,figure,footer,header,hgroup,mark,menu,meter,nav,output,progress,section,time,video".split(','),i=e.length;while(i--){document.createElement(e[i])}})()

Лучшим вариантом решения будет присоединять файл .js в раздел <head> вашей страницы HTML:

<!--[if lt IE 9]>
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->

 

Проверяем поддержку браузером определенных свойств CSS3

Здесь приводится простая функция jQuery для проверки поддержки браузером клиента определенных свойств CSS3. В данном примере проверяется свойство border-radius, но код можно легко модифицировать для проверки другого свойства.

Примечание: нужно опускать тире при передаче имени свойства в качестве парметра. Например, вместо  border-radius, нужно вводить “borderRadius” или “BorderRadius”.

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';

 

Получаем параметры URL

Получение параметров URL с помощью jQuery - очень простой процесс.

$.urlParam = function(name){
	var results = new RegExp('[\\?&]' + name + '=([^&#]*)').exec(window.location.href);
	if (!results) { return 0; }
	return results[1] || 0;
}

 

Отключаем клавишу “Enter” в формах

По умолчанию, форма может быть отправлена нажатием клавиши “Enter”. Но в некоторых формах такой функционал может оказаться лишним и порождать некоторые проблемы при вводе данных. Ниже приведенный код подавляет функционирование клавиши “Enter” в форме.

$("#form").keypress(function(e) {
  if (e.which == 13) {
    return false;
  }
});

Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/gChbfexgYa8/lessons.php

Читать комменты и комментировать

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



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

10 вставок кода jQuery | | 2012-06-19 12:01:32 | | Статьи Web-мастеру | | jQuery вдохнул новую жизнь в JavaScript. В данном уроке приводится 10 вставок кода jQuery, которые облегчат решение повседневных задач, возникающих при создании веб приложений. Предварительная | РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
 
Поделиться с друзьями: