Забыли пароль?
Запросите новый здесь.

Голосование
Как часто вы посещаете данный сайт?

1 раз в день
1 раз в день
25% [2 Голосов]

1 раз в неделю
1 раз в неделю
25% [2 Голосов]

1 раз в месяц
1 раз в месяц
13% [1 Голос]

Очень редко
Очень редко
25% [2 Голосов]

Первый раз зашёл
Первый раз зашёл
13% [1 Голос]

Голосов: 8
Вы должны авторизироваться, чтобы голосовать.
Начат: 26.07.2022 08:08

Архив опросов
Случайная тема
Миничат
Только пользователи могут отправлять сообщения.

kazik
Offline
· 05.10.2024 11:04
Чудеса однако. Открылась кнопка "редактировать". Ура, товарищи! ab

Polarfox
OfflineAdmin
· 04.10.2024 17:04
настройки форума наверно

kazik
Offline
· 02.10.2024 08:30
Почему нельзя редактировать сообщения форума после отсылки хотя-бы20 мин.? Или это такая подлянка? Кто такую "дружественность" мог придумать?? ac

jikaka
OfflineAdmin
· 10.08.2024 08:06
ar

Redfield
Offline
· 10.07.2024 13:59
Карта развития представлена тут: https://gameraide.
..hread_id=3

Архив миничата
Сейчас на сайте
» Гостей: 10

Гости:
» [Ваш IP] 07:37:57
/Статьи
» 69.162.124.230 07:37:46
» 57.141.0.30 07:37:24
/Статьи
» 57.141.0.3 07:37:24
/Поиск
» 57.141.0.14 07:37:21
/Поиск
» 57.141.0.5 07:37:20
/Поиск
» 57.141.0.15 07:37:17
/Поиск
» 57.141.0.16 07:37:15
/Поиск
» 47.128.40.92 07:37:09
/Поиск
» 57.141.0.13 07:36:56
/Поиск

» Всего пользователей: 1,692
» Новый пользователь: yankoff
В базе имеется
аддонов: 951
тем: 137
Иерархия статей
Динамическое изменение ширины страницы
Многие спорят о том, какой должна быть ширина страницы — фиксированной или растягивающейся (резиновой). Одним нравится фиксированный размер, другим наоборот. Попробуем угодить обоим типам, ведь любой пользователь коммерческого сайта есть потенциальный клиент, который может остаться на данной странице или уйти (вопрос юзабилити сайта). Я постарался решить разом эту проблему, предоставив выбор ширины страницы самому пользователю.

Решений данной задачи две. Первый — создать 2 шаблона сайта и добавить переключатель между ними на страницах сайта (на мой взгляд, не совсем удобно). Второй способ — реализовать анимированное изменение ширины страницы без её перезагрузки, а при переходе на следующую страницу сайта ширина страницы остается неизменной, так как данные о ширине сохраняются в cookie. Данный способ описан ниже.

Скрипт полностью проходит валидацию (еще бы, если учесть что тут 7 блоков div и только).

Необходима сама библиотека jquery и плагин jquery.cookie.

В файле css содержатся хаки для ie6, 7, я не стал отдельно выносить их в файл для краткости кода.

Не учтена проверка на отключенныe cookie, так как на практике лучше реализовывать сохранение параметров экрана в совокупности с сессиями, на стороне сервера. Весь код подробно прокомментирован.

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

-----------------------------------------------------------------------------------
$(document).ready(function(){

/* проверяем в cookie данные о разрешении страницы для её просмотра */
if ($.cookie("screen")== 'full') { /* Если предыдуший просмотр был на широком экране то */
/* Добавляем класс стилей широкого сайта для основных блоков */
$('#conteiner, #conteiner_2,#conteiner_3, #footer').addClass('tip_full');
window.sreen_1 = 'fix'; /* записываем первоначальное значение для кнопки изменяющей ширину страницы*/
window.sreen_2 = 'full'; /* вторичное значение*/
} else { /* во всех остальных случаях (включая по умолчанию) будет отображение узкого просмотра страницы */
/* Добавляем класс стилей узкого отображение страницы сайта для основных блоков */
$('#conteiner, #conteiner_2,#conteiner_3, #footer').addClass('tip_fix');
window.sreen_1 = 'full'; /* первичное значение */
window.sreen_2 = 'fix'; /* вторичное значение */
}

/* Функция изменения ширины экрана в зависимости от переданных ей параметров */
function size_screen (size_type_1,size_type_2) {

$('#start').css('display', 'none'); /* Защита от "дурака", многократного нажатия кнопки // убираем кнопку */

/* Присваиваем значения переменных в зависимости от переданного параметра (ширины экрана) */
if (size_type_1 == 'full') {
window.size_width = '100%'; /* значение ширины страницы */
} else {
window.size_width = '800px';
}

/* Функция jquery анимации. В данном случае плавного изменения ширины изображения страницы сайта */
$('#conteiner, #conteiner_2,#conteiner_3,#footer').animate({
'width': window.size_width /* Плавно изменяем ширину в соответствии с параметром отображения страницы */
},
500, /* Время анимации */
function() { /*Функция вызывающаяся после завершения анимации */
/* Удаляем предыдущие стили отображения страницы из блоков */
$(this).removeClass('tip_'+size_type_2);
/* Добавляяем новый класс стиля для нового ширины экрана */
$(this).addClass('tip_'+size_type_1);
/* Для очистки кода html от мусора удалим атрибут style ( созданный jquery) */
/* Данное действие не обязательно, оно несет эстетическую функцию */
$(this).removeAttr('style');

/* Защита от "дурака": многократного нажатия кнопки // показываем кнопку*/
$('#start').css('display', 'block');
});
/* Записываем в cookie параметр отображения сайта после перезагрузки или смены страницы */
$.cookie("screen", size_type_1, { path: '/'});

}

$('#start').toggle( /* Функция troggle выполняет последовательное многократное нажатие элемента (кнопки) */
function() { size_screen (window.sreen_1,window.sreen_2); }, /* первое нажатие */
function() { size_screen (window.sreen_2,window.sreen_1); } /* второе нажатие */
);
})

------------------------------------------------------------------------------

Скачать данное творение можно по следующей ссылке: jquery size, а посмотреть тут (красная фигня в правом верхнем углу и есть кнопка).

P.S. Автором данной статьи является Александр (balancev на gmail.com).

Поделиться этой статьей
Социальные закладки: Vkontakte Odnoklassniki Mail.ru Facebook Google Tweet This
URL:
BBcode:
HTML:

Нет комментариев.
Добавить комментарий
Пожалуйста, залогиньтесь для добавления комментария.
Рейтинги
5 (Отлично!) - 1 Голос

Рейтинг доступен только для пользователей.

Пожалуйста, авторизуйтесьили зарегистрируйтесь для голосования.