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

Голосование
Что вас интересует на нашем сайте больше всего?

База аддонов
База аддонов
17% [2 Голосов]

Форум, поиск ответов
Форум, поиск ответов
25% [3 Голосов]

Общение
Общение
33% [4 Голосов]

Новости
Новости
0% [0 Голосов]

Другое
Другое
25% [3 Голосов]

Голосов: 12
Вы должны авторизироваться, чтобы голосовать.
Начат: 16.05.2017 07:06

Архив опросов
Случайная тема
Друзья проекта
Unlogic W0rst Lab
All Fusion :: Плагины, моды, темы оформления для 6 и 7 версий PHP-Fusion
Система Smart для PHP-Fusion
Миничат
Только пользователи могут отправлять сообщения.

SchreiBear
Offline
· 15.10.2017 13:53
Тежёлый случай

Polarfox
OfflineAdmin
· 14.10.2017 17:40
BAD-DIMAN, работает, я же не наугад сказал. Прокси пробуй, может у вас тоже дебилы запрещатели? Или просто сломан интернет.

ovas
Offline
· 14.10.2017 16:16
SchreiBear Проблемы нету. Вопрос что ты хочешь от сайта и бюджете сайта. А так Руки с мозгами нужны чтоб клацали по мышке и клаве bv

SchreiBear
Offline
· 14.10.2017 13:56
ovas, тут нет.. ну а как по другому ты решиш проблему?

SchreiBear
Offline
· 14.10.2017 13:53
Агент кремля. Хорошо поёт и самое главное правду.. http://ok.ru/vide.
..0607458954

Архив миничата
Сейчас на сайте
» Всего: 11

» Гостей: 10
» Пользователей: 1
BAD-DIMAN

Гости:
» [Ваш IP] 13:12:53
/Статьи
» 51.255.65.95 13:12:52
/Поиск
» 164.132.161.91 13:12:44
/Архив миничата
» 164.132.161.16 13:12:23
/Поиск
» 46.229.168.71 13:12:15
/Поиск
» 46.229.168.78 13:12:02
/Поиск
» 164.132.161.2 13:11:44
/Поиск
» Yahoo [Bot] 13:11:22
/Поиск
» 193.201.224.17 13:11:17
/./moddb/error.php
» 69.162.124.235 13:11:01

» Всего пользователей: 1,317
» Новый пользователь: hobby58
В базе имеется
аддонов: 952
тем: 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 Голос

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

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