« Поставить закладку » « Сделать стартовой »

« Форумы » « Блоги » « Статьи » « Новости » « Файлы » « Realcoding IRC » « Site map » « Поиск »


Главная Главная
Анонсы Анонсы
Форумы Форумы
Каталог Каталог
Поиск Поиск
Опросы Опросы
Книжный магазин Книжный магазин
Реклама на сайте
Публикации Публикации
Партнеры Партнеры
Карта Карта сайта
Рассылки Рассылки
RSS экспорт
Настройки Настройки
О нас пишут О нас пишут
Контакты Контакты
Гостевая книга Гостевая книга


ПнВтСрЧтПтСбВс
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31        
    Популярное
Функция AccessResource

Строка состояния

Переходим с PHP на Perl, как это ни печально...

Использование Debug API: пример перехвата вызовов функций Win32 API

Динамический SQL в программах на PL/SQL. Использование пакета DBMS_SQL.

Урок 7. Компонент TUpdateSQL.

Анализ статистики базы данных InterBase/FireBird

Функция date() - вывод даты и времени в PHP

Определение IP-адреса с помощью Perl

Имперсонация и делегирование в ASP.NET (ASP.NET delegation and impersonation)




    Архив файлов



    Сообщества

    Документация

    Кто на сайте
Вы не зарегистрированы.
Имя:

Пароль:

Запомнить

Регистрация позволит Вам пользоваться дополнительными сервисами.
Сейчас на сайте:
Гостей: 167
Пользователей: 0

Статьи:: Интернет технологии :: AJAX :: jQuery для верстальщика (часть 2): вкусные меню



отправить ссылку другу версия для печати  Обсудить на форуме

jQuery для верстальщика (часть 2): вкусные меню

Это вторая статья о jQuery, которая будет интересна, прежде всего, начинающим пользователям этой библиотеки. В этой статье, с практической точки зрения, речь пойдет о подсветке текущего элемента меню на стороне клиента. А прочитав статью, вы поймете, как делать более сложные выборки и цепочки запросов.



Задача №2: вертикальное меню

Меню – фундаментальный элемент пользовательского интерфейса, как GUI, так и веб-приложений. На нескольких небольших примерах мы посмотрим, как с помощью jQuery создать элемент навигации. К тому же изучим обещанные возможности функции $(…) по работе со свойствами элементов.

Вертикальные меню представляют собой обычные списки ссылок:

<ul>
	<li><a href="/menu.html">Главная</a></li>
	<li><a href="/articles.html">Статьи</a></li>
	<li><a href="/forum.html">Форум</a></li>
	<li><a href="/links.html">Ссылки</a></li>
	<li><a href="/about.html">О нас</a></li>
</ul>

Его можно оформить очень красиво через таблицы стилей, и очень бы хотелось, что текущий раздел меню был подсвечен жирным шрифтом (или выделен как-то по-другому), чтобы дать пользователю понять, где он сейчас находится. Действовать можно по-разному: либо на стороне сервера, либо на стороне клиента. Серверный скрипт может при генерации страницы определить, какой пункт меню соответствует текущей странице, и пропишет нужный класс у элемента списка. У этого варианта есть недостатки: придется писать систему генерации меню на стороне сервера, при использовании же готовых скриптов трудно будет модифицировать модуль по работе с меню, а иногда возможность написания серверных скриптов отсутствует как таковая. Второй вариант лишен выше перечисленных недостатков. И для этого надо написать опять одну строчку в конструкции $(document).ready:

 

$("a[@href$=" + document.location.pathname + "]").css({fontWeight: "bold"})

Как вариант, можно использовать несколько другой подход, который предложил посмотреть профиль PaulColomiets:

 

var a = $("a[@href$=" + document.location.pathname + "]");
a.parent().text(a.text()).addClass('selected');

посмотреть профиль PaulColomiets Справедливо замечает, что выбирать лучше не просто тег a, но и необходимо указать более полный путь до него.

ayavryk

Как это работает

При изменении формата ссылок (я использовал относительные пути), необходимо будет поменять и скрипт. Что касается одной строчки, которая делает всю работу, то в ней используется уже знакомая функция $(…), которая в данном случае выбирает все ссылки с значением атрибута href, заканчивающегося на document.location.pathname. В этой переменной в свою очередь хранится путь до текущей страницы. Также мы используем метод css для установки значения параметра каскадных таблиц стилей font-weight. Если вы обратили внимание, то название параметра font-weight, написано немного по-другому fontWeight, то есть стилем «верблюд», который используется в JavaScript. В качестве завершающего штриха предлагаю сделать так, чтобы клик по элементу меню текущего раздела отменялся. Это очень разумное решение, ведь нельзя перейти на страницу, на которой уже находишься. А еще мне удастся продемонстрировать цепочку вызовов, которые постоянно используются в скриптах с jQuery:

 

$(document).ready(function() {
	$("a[@href$=" + document.location.pathname + "]")
		.css({fontWeight: "bold"})
		.click(function() { return false; } );
});

Выводы

У нас получилось обойтись без дополнительных переменных, что сокращает код в простых случаях без ущерба ясности. В этом исходнике вы можете также посмотреть стиль оформления, который удачно подойдет в таком случае: вместо одной строчке, я бью цепочку вызовов на несколько, чтобы показать, где вызовы происходят. Я думаю, что теперь не составит труда изменить скрипт для прикрепления «стрелочки», только к внешним ссылкам. Очень рекомендую посмотреть для простоты, какие операторы эквивалентности есть кроме «$=», и что именно они делают.

Цикл статей

Автор: http://blv.habrahabr.ru/




Рубрика: AJAX




VivaMP - инструмент для OpenMP.

OpenMP

Инструмент для программистов VivaMP предназначен для помощи разработчикам параллельных программ на базе OpenMP. В статье приведен краткий обзор программного продукта.


Подробнее... | Рубрика: OpenMP | Добавлено: 05.12.2008

Создаем контекстно-зависимое WPF-приложени....

Windows 7

Начинаем цикл публикаций, призванных помочь начинающим программистам в создании контекстно-зависимых приложений для Windows 7. Об этом много говорили на PDC да и мы неоднократно писали о этом новом классе приложений. Пользователи Windows 7 build 6801 могли заметить появление в гаджете погоды опции автоматического определения местоположения компьютера. И сегодня у вас появилась уникальная возможность попробовать себя в создании подобных приложений.


Подробнее... | Рубрика: Windows 7 | Добавлено: 05.12.2008

Windows Vista SP2: что внутри и что важно?.

Windows Vista

В связи с началом программы Customer Preview Program (CPP) для Windows Vista® Service Pack 2 (SP2) хотелось бы вкратце рассказать об основных особенностях этого пакета, а также призвать вас к его загрузке и тестированию. Windows Vista SP2 представляет собой традиционный пакет сервисных обновлений, включающий все накопительные обновления безопасности, выпущенные с момента релиза SP1 в марте 2008 года. Кроме того, Windows Vista SP2 добавляет поддержку новых типов устройств и развивающихся стандартов, которые обретут популярность уже в ближайшее время, и включает все хотфиксы, обнаруженные через программу улучшения качества ПО (CEIP).


Подробнее... | Рубрика: Windows Vista | Добавлено: 05.12.2008

Остальные статьи:

Вышел MySQL 5.1.30, первый стабильный рели...
Тестирование параллельных программ
Архитектура AMD64 (EM64T)
Платформа 2009. Определяя будущее
Windows Vista Bridge Sample Library - упра...
Оптимизация 64-битных программ
Подгрузка через AJAX HTML-кода, содержащег...
Обзор нового релиза самой мощной Ajax библ...
Firebug 1.3 и 1.4 alpha — что нового и инт...
Релиз Microsoft Silverlight 2.0. Что новог...
XML документация в C#
Курсоры в MySQL 5
Microsoft опубликовала подробности о сесси...
Microsoft делится подробностями о том, что...
Тестируем новый javascript от нового брауз...
MySQL Query Cache
Использование провайдеров компиляции в As...
Чего мы ждем от C# 4.0
Delphi 2009 и C++Builder 2009
Джоэл Спольски и Джеф Этвуд запустили новы...


Цитата дня (все,добавить):

Портал фрилансеров

работа на дому


    Рубрикатор

Программирование

C/С++
Обучение
Windows API
XAML
Моделирование
Паттерны
Visual Basic 7 .NET
WxWidgets
Функции WinApi
Функции С++
Разработка под Mac OS
Eiffel
Visual Studio 2008
UI дизайн
Алгоритмы
Конкурсные статьи
Turbo Pascal
Visual Studio
CASE-средства
Visual Studio 2005
Без VCL
Delphi
Тех. документация
Тестирование
Software Testing
ООП
TCP/IP
Google Android
Windows Installer
.NET Framework
Драйвера
C# C Sharp
Справка
Проектирование
Информ. системы
Visual Basic
Assembler
Оптимизация кода
Gtk+
Компоненты
Реинжиниринг
Управление проектами
Extreeme programming
Lotus Notes
Алгебраическое проектирование


Интернет технологии

PHP
Perl
ASP
WAP
Cookies
SSI
CGI
Web Servers
VB Script
DNS
CSS
XML
Html
Java Script
Java2ME
Firewall
Flash
.htaccess
Apache
VRML
Протоколы
Поисковые системы
Технология JAVA
Учебник по PHP
Учебник по JavaScript
Учебник по XML
Java Q&A
AJAX
DHTML
XHTML
Dreamweaver
Web 2.0
Python
Вебмастеру
Cisco
Ruby on Rails
Silverlight

Базы данных

Access
InterBase
MySQL
Oracle
ADO .NET
Основы SQL
Учебник по Access 2002
MS
Microsoft FoxPro
Доступ к данным
XML в MS SQL Server 2000
ODBC и MyODBC
Обучение
Caché
DB2
PostgresSQL
Sybase
Теория
Хранилища данных
Безопасность
Реляционные данные
MySQL и mSQL

Остальное:

Разное
Обзоры книг
Безопасность
Графика и дизайн
Юмор
Linux
Фракталы
Microsoft Axapta
Многоядерность
Сети
Microsoft Office
Работа
MS-DOS
Криптография
Графика и игроделание
Новости SDK
Системы защиты
Учебник по AutoCad
CVS
Windows XP
Windows Server 2003
Windows Vista
Windows 7
Мероприятия