Стили и дизайн (Статей: 11)

Друзья, админы сайта visavi.net поправьте пожалуйста немного дизайн тёмной темы, а то в некоторых моментах как на скринах нужен светлый text-color

image
image
Многие комбинации могут быть вам уже известны.

Ctrl + A - выделить ВСЕ
Ctrl + C - копировать
Ctrl + V - вставить
Ctrl + N - новый документ
Shift + Ctrl + N - новый слой

Ctrl + S - сохранить
Shift + Ctrl + S - сохранить как...
Alt + Shift + Ctrl + S - сохранить для Web
Ctrl + Z - вернуть назад
Alt + Ctrl + Z - вернуть на несколько шагов назад
Shift + Ctrl + Z - вернуть на шаг вперед

Ctrl (-) - уменьшение изображения
Ctrl (+) - увеличение изображения
Alt + Ctrl + 0 - натуральный размер изображения

●Вызов часто используемых инструментов:

B - кисть
E - ластик
H - рука (то же действие выполняет "пробел")
L - лассо
M - выделение
P - перо
T - текст
V - перемещение
D - установить цвета черный/белый
X - поменять цвета местами
[ - уменьшает размер кисти
] - увеличивает размер кисти

Ctrl + T – свободное трансформирование;
Ctrl + U – цветовой тон/насыщенность;
Ctrl + D - снять выделение;
Ctrl + Shift + U - обесцветить графическое изображение;
Ctrl + I - инвертирование цветов;
Ctrl + Shift + I - инвертирование выделения;
Ctrl + Shift + L - автоуровни изображения;
F6 - отобразить/скрыть палитру цветов;
Ctrl + B – цветовой баланс;
Ctrl + Alt + B - прежняя установка цветового баланса;
Ctrl + X или F2 – вырезать;
Ctrl + M – кривые;
Ctrl + Alt + M - последние установки кривых;
Ctrl + Shift + U – уменьшить насыщенность изображения;
Ctrl + Q и ALT + F4 – выход из программы;
Shift + Пробел или Shift + F5 – заливка;
Ctrl + ALT + D или Shift + F6 - растушевка выделенной области;
Ctrl + 0 – растяжение или сжатие изображения до размеров экрана.

●Горячие клавиши в Фотошопе для работы со слоями:

F7 – спрятать или отобразить палитру слоёв;
Alt + клик на изображении глаза палитры слоёв - просмотр отдельного слоя;
Ctrl+Shift+N - создание нового слоя и регулировка параметров смешивания;
Ctrl+Shift+Alt+N - создание нового слоя и обход установки параметров смешивания;
Ctrl + J - клонирование выделения в новый слой;
Ctrl + Shift + J - преобразование выделения в новый слой и удаление его из фонового слоя;
Ctrl + A, Ctrl + J - дублирование слоя в новый слой;
Shift + Alt + ] - переход на верхний слой;
Alt + ] – перемещение на один слой вверх;
Alt + [ - перемещение на один слой вниз;
Shift + Alt + ( - переход на нижний слой;
Shift + Alt + клик правой кнопкой мыши на изображении любым инструментом фотошопа - переход на слой, который содержит указанное изображение;
Ctrl + клик по имени слоя в палитре слоёв - преобразование маски прозрачности выбранного слоя в контур выделения;
Ctrl + Alt + клик по имени слоя в палитре слоёв - вычитание маски прозрачности из выделения;
Ctrl + Shift + клик по имени слоя в палитре слоёв - добавление маски прозрачности выбранного слоя в контур выделения;
+ (+) и +(-) при активном выделяющем инструменте - смена режимов смешивания слоёв;
Ctrl + ] - Перемещение слоя на один уровень вперед;
Ctrl + Shift + ] - Перемещение слоя на передний план;
Ctrl + [ - Перемещение слоя на задний план;
Ctrl + Shift + [ - перемещение слоя назад и расположение его перед фоновым слоем;
Shift + Alt + N - возврат в режим нормального смешивания;
Ctrl + E - слияние текущего слоя с нижним;
Ctrl + Shift + E - объединение видимых слоев;
Ctrl + Alt + E - клонирование содержимого всех связанных слоев в активный;
Ctrl + G - группировка с предыдущим слоем;
Ctrl + Shift + G - разгруппирование слоёв;
Ctrl + E - объединение связанных слоёв;
Alt + клик на горизонтальной прямой палитры слоёв или Ctrl + G – группировка соседних слоёв;
Ctrl + Shift + Alt + E - клонирование содержимого всех видимых слоев в активный;
Alt + клик по пунктирной прямой палитры слоёв или Ctrl + Shift + G – разгруппирование соседних слоёв;
От Ctrl + 1 до Ctrl + 5 в диалоговом окне эффектов – переключение эффектов слоя;
Ctrl + клик по значку страницы внизу палитры слоёв - создание слоя настройки;
Alt + команда эффектов - блокировка эффектов определенного слоя;
Ctrl + Shift + S - сохранение «плоской» копии изображения со слоями.
Здравствуйте!
Наверное многим не нравится когда с их сайта что-то "копипастят".
Сейчас я вам расскажу как усложнить копирование графики (а именно иконок) с помощью css.
Все наши иконки будут вида
<i class="icon-ICON_NAME "></i>
.
Сначала создадим файл icons.css и подключим его к сайту.
В этом файле пропишем:
[color=#0000ff][class^="icon-"],[class*=" icon-"] {
   width: 16px;
   height: 16px;
   display: inline-block;
   vertical-align: text-top;
}[/color]
где

width: 16px; - ширина иконки
height: 16px; - высота иконки

и далее уже создаем див самой иконки:
.icon-icon_name {
    background: url(путь к иконке) no-repeat;
}
Затем icons.css можно собрать с основным стилем и прогнать его через сервис оптимизации который удалит все переносы и комментарии что сделает код еще менее читабельным.
Автор статьи: KpuTuK (http://KpuTuK.ru)
В этой статье хочу поднять тему фиксированных по ширине wap-дизайнов.
Если не ошибаюсь, вопрос подобный не поднимался ни кем ранее, а следовало бы.
Сколько точно процентов сайтов используют фиксированные по ширине шаблоны я не считал, могу лишь предположить что это число весьма велико, около 80% (в Российском сегменте мобильного интернета).
Почему так вышло? Так удобнее сидеть на мобильном сайте с компьютера.
Но отдавая приоритет ПК при создании дизайна для мобильного дизайна мы совершенно наплевательски относимся к пользователям мобильных устройств.
Как правило атрибут max-width в CSS варируется, но присутствует.
Достигает 480px, возможно больше, но это редкость.
Раньше, года 3 тому назад подобный подход был логичен. Максимальная ширина экрана мобильного была около 400 пикселей, то есть сайт отображался на любом устройстве того времени во всю ширину дисплея.
Сейчас же разрешение ряда мобильных устройств в районе 480x800, при горизонтальном просмотре мобильного сайта (ширина 800px) wap шаблон выглядит весьма неудобно, занимает всего лишь 50% от предоставленного места, что ухудшает юзабилити, текст в подобном формате читать неудобно.
Я привел некоторые аргументы в пользу того что следует отказаться от фиксированной ширина wap-сайта, к чему вас и призываю. А для посещения сайта с пк следует разрабатывать отдельные WEB версии. Благо Ротор и прочие CMS это позволяют с легкостью реализовать.
Значение прозрачности действует на все дочерние элементы внутри, а не только на фон.
Диапазон значения: от 0 до 1
Чем ближе к 1 - тем прозрачнее.
Попробуйте поэкспериментировать с этим свойством используя его при наведении (hover).
CSS Crib Sheet
При верстке сайта с помощью CSS вы обязательно наткнетесь на множество проблем. И всякий раз вы будете биться головой об стену в попытках обойти очередной глюк. Данный документ призван облегчить вам процесс разработки, и служит кратким справочником, к которому вы можете обращаться всякий раз, когда столкнетесь с непреодолимым препятствием.

Если у вас есть что добавить к этому документу, оставьте свой комментарий здесь.

Данный документ переведен на французский, немецкий, испанский, итальянский, венгерский, финский, русский, японский и китайский языки.

Что-то не так? Проверьте код валидатором!
При отладке своего кода вы сэкономите уйму времени и нервов, если в первую очередь проверите его валидатором. Чаще всего проблемы с компоновкой страницы вызваны неверным XHTML или CSS.
Создавайте и тестируйте свой CSS-код сначала в современных "продвинутых" браузерах, и лишь затем - в остальных, но не наоборот
Если вы тестируете сайт в некачественном браузере, ваш код начинает зависеть от неправильного отображения этим браузером. Когда настанет время проверить сайт в браузерах, верно поддерживающих стандарты, вы наверняка огорчитесь увиденным. Таким образом, начните с передовых браузеров, а потом добавляйте к коду трюки для менее удачных. Таким образом ваш код с самого начала будет соответствовать стандартам, и вам не придётся слишком много "колдовать" для поддержки других браузеров. Сегодня самыми передовыми браузерами являются Mozilla, Safari, или Opera.
Удостоверьтесь, что желаемый эффект действительно существует.
Существуют расширения CSS, специфичные для конкретных браузеров, но не входящие в официальную спецификацию каскадных таблиц. Если вы пытаетесь применить свойство filter или отформатировать внешний вид полосы прокрутки, знайте - вы используете специфичный код, работающий только в IE. Если валидатор вдруг пишет вам, что ваш код не соответствует спецификации, скорей всего это из-за того, что в нем присутствует такое специфические расширение, и оно не будет работать в других браузерах.
Применяя плавающие блоки, убедитесь в том, что они не мешают соседям
"Плавающие блоки" коварны, и они не всегда ведут себя так, как ожидается. Если вдруг получилось так, что плавающий блок вылезает за пределы содержащего его элемента, или же он ведет себя не так, как вы хотите - удостоверьтесь в корректности того, чего вы хотите добиться. Обратитесь за подробностями к руководству Эрика Мейера.
Поля (margins) всегда "сворачиваются". Пользуйтесь вместо них отступами (padding) или границами
Если у вас вдруг появляется пустое пространство там, где оно вам не нужно, или наоборот - нету свободного пространства там, где оно вам нужно, это скорей всего происходит из-за полей (margins), которые имеют привычку "сворачиваться". Andy Budd в своей статье описывает этот глюк и дает советы, как его избежать.
Старайтесь не задавать элементу одновременно отступ/границу И фиксированную ширину
IE5 неправильно реализует блочную модель CSS, из-за чего ваша страница может превратиться в кашу. Существует несколько уловок обойти этот глюк, но лучше всего вообще с ним не связываться: задавайте нужный отступ в родительском элементе, а фиксированную ширину - в дочернем.
Как избежать мелькания чистого HTML в IE
Если вы используете внешнюю таблицу стилей, подключая ее с помощью директивы @import, то рано или поздно вы заметите, что IE успевает "сверкнуть" на экране неформатированным HTML прежде, чем применит к нему стили. Эту проблему можно решить следующим образом.
Не используйте min-width в IE
Он не поддерживает это свойство. Но он рассматривает width как min-width в некоторой степени, поэтому с помощью небольшого фильтра для IE, вы можете получить точно эффект min-width в IE.
Если что-то не так, уменьшите ширину
Иногда из-за погрешностей округления сложение вида 50% + 50% даёт в итоге что-нибудь типа 100.1%. Это приводит к тому, что заботливо созданная вами вёрстка "расползается" в некоторых браузерах. Лечится просто: уменьшайте ширину с 50% до 49% или даже 49,9%.
IE показывает все не так, как надо?
Возможно, вы напоролись на знаменитый "Peekaboo bug", особенно если баг проявляется при наведении курсора на ссылку. Смотрите решение в статье "Позиция - это наше всё!"
Будьте осторожны, задавая стили для "якорей"
Если в своем коде вы используете классические якоря (<a name="anchor">), то скоро заметите, что они тоже реагируют на псевдо-классы :hover и :active. Избежать этого можно, применив к якорям id, или же применяя для них слегка извращенный синтаксис типа :link:hover, :link:active
Помните о порядке описания ссылок.
Задавая псевдоклассы для ссылок, делайте это всегда вот в таком порядке: Link, Visited, Hover, Active (запомните этот порядок с помощью слов "LoVe/HAte"). Любые другие комбинации не работают так, как надо. Если требуется использовать также и псевдокласс :focus, то порядок описания будет таким: Link, Visited, Hover, Focus, Active (LVHFA для запоминания чего Мэтт Холи придумал фразу "Lord Vader's Handle Formerly Anakin")
Помните о правиле "TRouBLEd" для границ.
Значения для границ, полей (margins) и отступов (padding) сокращённо описываются в таком порядке: по часовой стрелке в направлении Top, Right, Bottom, Left (верхнее, правое, нижнее, левое). Таким образом, запись margin: 0 1px 3px 5px; означает, что верхней границы нет, левая равна пяти пикселям ну и так далее.
Явно указывайте единицы измерения у ненулевых значений
Спецификация CSS требует указывать единицы измерения для всех величин, связанных с размерами, отступами или шрифтами (единственное исключение - line-height, как это ни странно). Поведение отдельных браузеров в ситуациях, когда единицы измерения не указаны, может быть совершенно неожиданным. Что касается ноля, то ноль есть ноль независимо от того, измерять ли его пунктами, пикселями или чем-то ещё. Единицы измерения для него не нужны. Пример: padding: 0 2px 0 1em;
Тестируйте различные размеры шрифта
"Продвинутые" браузеры типа Mozilla и Opera позволяют менять размер шрифта вне зависимости от единиц, в которых он задан. У некоторых пользователей непременно шрифты будут настроены так, что их размер в браузере окажется меньше или больше вашего. Пытайтесь оптимизировать ваш код под максимально возможный диапазон размеров шрифта.
Не забывайте о прописных и строчных буквах
Некоторые броузеры строго относятся к регистру букв. Если вы назвали свой класс "homePage", старайтесь и в стилевых таблицах использовать в точности такое же имя, так как в строгих броузерах (таких как Mozilla) имя "homepage" не эквивалентно "homePage".
Тестируйте, включив стили в код страницы; публикуйте в Сети, убрав стили во внешний файл.
Работая со стилями, размещёнными в HTML-коде страницы, вы не столкнетесь с возможными ошибками при тестировании, связанными с кэшированием. Это особенно важно при работе с некоторыми браузерами на Mac-платформе. Но не забудьте перед переносом сайта в сеть вынести все стили во внешний файл и подключить его через @import или <link>.
Работая над ошибками позиционирования, добавьте блокам чёткие границы
Универсальное правило типа div {border: solid 1px #f00;} может сослужить огромную службу при поиске ошибок позиционирования. Но добавив границы для отдельных элементов, вы сможете точно определить места, где блоки залазят друг на друга или же где появляется лишнее пустое пространство, что не всегда легко обнаружить.
Не используйте одинарных кавычек в описаниях путей для изображений
Задавая путь к фоновому изображению, откажитесь от навязчивого желания заключить его в кавычки. В них нет необходимости, кроме того, IE5 для Mac на этих кавычках просто заклинит.
Не подключайте пустые внешние файлы стилей в надежде заполнить их "когда-нибудь в будущем"
IE5 для Mac заклинит на пустом файле и скорость загрузки страницы возрастёт. Вместо этого поместите в файл хотя бы одно стилевое правило (или даже просто комментарий) - и MacIE снова вернется к жизни.
Кроме того, есть некоторые аспекты теории, которые не относятся напрямую к функциональности вёрстки, но, тем не менее, их следует соблюдать при разработке:

Упорядочьте свой CSS файл
Сопровождайте каждую группу стилевых правил своим комментарием, группируйте сходные по смыслу селекторы, определите для себя правила наименования селекторов и следуйте им неукоснительно, визуально "отбивайте" селекторы пробелом (рекомендуем использовать именно пробел, а не табуляцию - это условие кроссплатформенности) и соблюдайте порядок свойств.
Именуйте классы и идентификаторы, исходя из их назначения, а не внешнего вида
Создав класс .smallblue и решив впоследствии поменять в нём текст на большой и красный, вы тем самым перечеркнёте смысл его названия. Вместо этого используйте классы типов .copyright и .pullquote. (опираясь на функциональное назначение класса)
Полагайтесь на CSS-фильтры лишь как на самое последнее средство
CSS-хаки и фильтры позволяют выборочно применять стили (или не применять - и такое бывает) к различным элементам. Избегайте применения их по любому поводу, пытайтесь найти более кроссбраузерные решения. Это порой здорово сохраняет нервы и время. На всякий случай вот огромный список CSS-фильтров.
Совмещайте селекторы
Чем легче CSS-файл, тем меньше требуется времени на его загрузку. По возможности группируйте селекторы, полагайтесь на наследование свойств, и уменьшайте объем текста, используя короткую запись свойств.
Применяя методы замены изображений, не забывайте о доступности
Классический метод замены изображения "FIR" создает проблемы при чтении страниц голосовыми браузерам, и в случаях, когда пользователь отключил загрузку изображений. Однако этому методу есть альтернативы.
Drop-Down Menus, Horizontal Style
Каждый, кому доводилось создавать выпадающие меню, знаком с тем, какое количество скриптов требуется для этого. Между тем, используя грамотно структурированный HTML-код и несложные CSS-правила, можно создать симпатичное выпадающее меню, которое легко менять и дополнять, и при этом оно будет работать во множестве браузеров, в том числе и в Internet Explorer. И самое главное для вас, любители "чистого" кода - никакого JavaScript! (На самом деле, небольшой скрипт все же необходим, но вовсе не для того, о чём вы подумали.)
Вот пример меню:
http://www.alistapart.com/d/horizdropdowns/horizontal.htm
Создаем меню
Первым и самым важным этапом создания нашего меню является построение его структуры. Лучше всего делать это, используя ненумерованный список, в котором размещены подменю, выступающие как списки в рамках пунктов родительского списка. Звучит заумно? Фактически это очень просто:
<ul> 
  <li><a href="#">Home</a></li> 
    <li><a href="#">About</a> 
    <ul> 
        <li><a href="#">History</a></li> 
        <li><a href="#">Team</a></li> 
        <li><a href="#">Offices</a></li> 
    </ul> 
  </li> 
  <li><a href="#">Services</a> 
  <ul> 
      <li><a href="#">Web Design</a></li> 
      <li><a href="#">Internet Marketing</a></li> 
      <li><a href="#">Hosting</a></li> 
      <li><a href="#">Domain Names</a></li> 
      <li><a href="#">Broadband</a></li> 
    </ul> 
    </li>
    <li><a href="#">Contact Us</a> 
    <ul> 
      <li><a href="#">United Kingdom</a></li> 
      <li><a href="#">France</a></li> 
      <li><a href="#">USA</a></li> 
      <li><a href="#">Australia</a></li> 
    </ul> 
    </li> 
</ul>

Вот так: простой HTML код, доступный и легко редактируемый.
Наводим красоту
Взгляните на приведённый выше пример. Вы увидите довольно скучный список элементов. А я обещал вам, что он будет симпатичным! Давайте-ка добавим немного стилей.

Первым делом удалим отступы и маркеры в ненумерованном списке, а затем зададим ширину пунктов меню.
ul {
margin: 0;
padding: 0;
list-style: none;
width: 150px;
}
Теперь нам надо задать положение элементов списка. К счастью, они по умолчанию будут расположены вертикально, что нам и нужно. Однако, нам необходимо задать значение для position как relative, и всё потому, что нам нужно будет относительно их абсолютно позиционировать подменю
ul li {
position: relative;
}
Берёмся за подменю. Мы хотим, чтобы каждое подменю появлялось справа от пункта родительского меню в тот момент, когда над этим пунктом находится курсор.
li ul {
position: absolute;
left: 149px;
top: 0;
display: none;
}
Используя атрибуты "left" и "top", мы можем абсолютно позиционировать каждое субменю в рамках пункта меню предка. Вы заметите, что я задал атрибуту "left" значение в 149px (одним пикселем меньше, чем ширина родительского пункта), это позволяет субменю перекрывать главное меню, не создавая при этом двойной границы. (Поймёте, о чём я, чуть позже.)Нам надо также присвоить атрибуту "display" значение "none", так как мы не хотим видеть подменю при открытии страницы.

Что ж, у нас теперь есть каркас, но он всё ещё выглядит невзрачно. Давайте зададим стили для ссылок.
ul li a {
display: block;
text-decoration: none;
color: #777;
background: #fff;
padding: 5px;
border: 1px solid #ccc;
border-bottom: 0;
}
Я применил к ссылкам стили по своему вкусу, но их можно легко поменять на те, что вам нравятся. Важно присвоить атрибуту "display" значение "block", ведь мы хотим, чтобы каждая ссылка занимала всё отведённое для неё место внутри содержащего её элемента списка.Итак, выглядит уже получше, хотя пользователи Internet Explorer для Windows могут с вами и не согласиться. К несчастью, IE Win понимает разрывы строк между ссылками в нашем красиво оформленном HTML коде как незаполненное пространство. Из-за этого в IE вы видите, что ссылки не прилегают тесно одна к другой. Однако этот баг IE можно обойти.
/* Fix IE. Hide from IE Mac \*/
* html ul li { float: left; }
* html ul li a { height: 1%; }
/* End */
Выше мы применили трюк Holly Hack, которые прячет эти правила от всех браузеров, кроме IE Win. Отлично. Обратите внимание, что было добавлено правило height: 1%. К сожалению (опять!), борясь с одной ошибкой, мы выткнулись на другую, для борьбы с которой требуется задать значение для атрибута "height", чтобы ссылки отображались как блочные элементы.
Также обратите внимание, что мы забыли "закрыть" блок меню. Добавим дополнительно нижнюю границу к каждому элементу списка. Итак, вот полный список стилей для ul:
ul {
margin: 0;
padding: 0;
list-style: none;
width: 150px;
border-bottom: 1px solid #ccc;
}
Все сложилось удачно, и теперь все могут увидеть красивое, но нефункционирующее меню.
Заставим его работать
А теперь - самое веселое. Нам надо сделать так, чтобы подменю появлялись в тот момент, когда курсор находится над элементом списка.
li:hover ul { display: block; }
Вуаля! И вот оно - наше меню - в действии.

"Ё-моё! Работает!" - крикнет кто-то из вас. - "Здорово!"

Хорошо, хорошо, но чёртов IE/Win опять поломал всю красоту - не желает делать то, что ему сказано. Он понимает псевдокласс :hover лишь для тега <a> - так что li:hover, на который у нас завязано появление подменю, ему ни о чём не говорит.

Капелька JavaScript приведет IE в чувство (разрыв строк отмечен символом "»" - Ред.):

startList = function() {
  if (document.all&&document.getElementById) {
    navRoot = document.getElementById("nav");
    for (i=0; i<navRoot.childNodes.length; i++) {
      node = navRoot.childNodes[i];
      if (node.nodeName=="LI") {
        node.onmouseover=function() {
          this.className+=" over";
        }
        node.onmouseout=function() {
          this.className=this.className.replace »
        (" over", "");
        }
    }
    }
  }
}
window.onload=startList;
Итак, правила для hover таковы:
li:hover ul, li.over ul { 
display: block; 
}
Мы также должны дополнительно связать JavaScript с нашим главным списком, добавив это:
<ul id="nav">
Надеюсь, учитывая всё вышерассмотренное, любой из вас сможет увидеть упрощённую версию действующего меню.
Прыжки меню в IE5.01 для Win
Пользователи IE5.01 для Windows заметят, как меню прыгает вокруг при наведении мыши на любой из элементов списка. Проблема легко решается внесением изменений в наш прошлый трюк:
/* Fix IE. Hide from IE Mac \*/
* html ul li { float: left; height: 1%; }
* html ul li a { height: 1%; }
/* End */
Таинственный баг шестой версии IE:Работая над статьёй, я обнаружил странный баг, который, как мне кажется, наблюдается лишь в IE6. Для "li a" необходимо задать фон, иначе если выпадающее подменю будет больше (по высоте), чем само родительское меню, то часть ссылок просто исчезнет с экрана ещё до того, как вы сможете кликнуть по ним. Странно! Попробуйте увидеть это сами. krut
Все в гиперпространстве связанно между собой гиперссылками. Почти каждый переход с одной страницы на другую страницу подразумевает предварительный щелчок мышью по определенной ссылке. Как дать посетителю сайта знать о том, что он уже посещал страницу, на которую ведет определенная ссылка?

Известно достаточно много методов для того, чтобы дать пользователю знать о том, что он уже посещал конкретную страницу в интернете. Какой из этих методов самый подходящий? Цветовое определение ссылок? Подчеркивание? Картинка? При ответе на этот вопрос не стоит забывать о дальтониках, о карманных компьютерах, и, конечно же, не стоит забывать о браузерах, вернее браузере - всеми любимый ослик - Internet Explorer. Появившуюся седьмую версию этого браузера можно называть уже посолидней – осел. Но эта тема для отдельной статьи.

Итак, начнем с Якоба Нильсена – эксперта по удобству и простоте использования. Краткое изложение его статьи по визуализации ссылок (Guidelines for Visualizing Links):

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

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

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

Цвет не посещенных ссылок должен быть ясным, ярким и насыщенным чем цвет посещенных ссылок, которые должны выглядеть размытыми и тусклыми. Два цвета, отличающие один тип ссылок (которые не открывались) от другого типа ссылок (которые открывались ранее) должны быть оттенком одного и того же цвета. Оттенки голубого цвета больше всего сигнализируют о том, что это ссылка.

Метод Симона Коллисона был признан как один из самых практичных и оригинальных методов. Идея достаточно проста и хорошо подходит для списков со ссылками. На сайтах можно увидеть галочку, которая появляется напротив той ссылки, по которой посетитель уже щелкал мышью или раньше был на странице, куда ведет адрес ссылки. Весь эффект полностью создается в CSS, т.е. XHTML код страницы остается нетронутым. Если внести некоторые изменения в CSS код Симона, то этот метод можно применять к обычным ссылкам, которые не находятся в списках. CSS код этого метода:

ul {
list-style-type:no ne;
padding:3px;
}
li a {
display:block;
line-height:150%;
width:239px;
background:URL(ticks_grey.gif);
text-decoration:no ne;
}

li a:link, a:active {
color:#666;
}

li a:hover {
color:#F33;
background-position: 0 -20px;
}

li a:visited {
background-position: 0 -40px;
}
При этом XHTML код страницы выглядит очень просто:


<ul>
<li>адрес ссылки</li>
<li>еще один адрес ссылки и т.д.</li>
</ul>
Internet Explorer тормозит широкое использование уже давно появившихся псевдо-элементов be fore и :after, которые могут идеально выполнять необходимую функцию определения уже посещенных ссылок. Почти все современные браузеры поддерживают эти элементы.

Для псевдо-элементов be fore и :after Майк Дэйвидсон (и несколько людей до него) предложил вместо текста использовать знак корня (радикал) – своеобразная галочка. Но эта галочка является не картинкой, а unicode символом ( \221A ), который появляется после ссылки, по адресу которой уже был определенный посетитель. Весь код также находиться в CSS и выглядит следующим образом:

a:visited:after {
content: "\00A0\221A";
font-size: 75%;
}
\00A0 означает непрерывающиеся пустое место (вместо пробела).

Я думаю, что различные галочки иногда могут вводить пользователя в заблуждение. В его понимании этот знак может нести в себе другой смысл. Поэтому необходимо дать знать посетителю сайта о том, какую роль выполняет определенный символ после ссылок. klass
Сразу оговорюсь: формулировка у меня хреновая, но надеюсь что смысл написанного ниже дойдет до читателя))

Как-то просматривая стиль на одном сайте, наткнулся на строчку вида
input[type="button"] { применение стиля }.
Столкнулся с таким впервые, и ессно начал методом тыка разузнавать подробней.

В итоге:
Можно разукрасить поля ввода.
К примеру на венике гостевая. Там при добавлении сообщения три поля ввода, имена которых author (ник), message (сообщение) и code (код с картинки).
Пишем в стиле:
input[name="author"] {background-image: url("/dir/.../image.gif"); background-repeat: no-repeat /*чтоб картинка не повторялась, ибо смотреться хреново будет*/ }
Подробней:
В стиле указано input[name="author"] {...}
То есть если в html коде страницы встретиться поле ввода input, с атрибутом name, значение которого равно author, то будет применен отдельный стиль, в данном случае бэкграунд-картинка.
Так же само можете сделать и для остальных полей ввода, имена их перечислены выше.
Но это так сказать более идентификационно, то есть только для одного поля ввода, для ввода ника. А если нужно к примеру во всех полях ввода добавить черный фон и белый текст?
Тогда пишем
input[type="text"] {background: #000; color: white}
то есть для всех полей ввода текста (type="text").

Несколько атрибутов со значениями.
input[type="text"][name="other"] {...}
В данном случае стиль будет применяться к полю ввода только в том случае, если тип равен "text" а имя равно "other". Только в том случае будет применятся стиль.

Атрибут без элемента.
[align="center"] {color:red}
В данном случае красный цвет будет между теми тегами, у которых align="center"
Это может быть и <div> и <span> и <p>, но если он имеет атрибут align значение которого center, то содержимое будет красного цвета.

Используя это всё, уберем средствами css рекламную ссылку на хомяке, которая имеет вид httр://a2.h2m.ru/i.php, иногда а1.
Код:
a[href="httр://a2.h2m.ru/i.php"], a[href="httр://a1.h2m.ru/i.php"] {visibility: hidden}
Таким макаром скрыли ссылки с пред ясных очей посетителей, но они остались в коде страницы. То бишь если бы средствами php вырезали ссылки, то можно было бы и без акка остаться, а так... И ссылки в коде, и не видно их :smile

К примеру многие пользуются на венике сервисами от мастокса. Там тоже вверху ихняя реклам.ссылка, но она не статичная как в хомяке, а генерируемая. Но начинается она с httр://ваппц.ру.
В этом случае:
[атрибут^="значение"] {... }
этом случае атрибут должен лишь начинаться с указанного значения, а не обязательно содержать его целиком.
То есть пишем
a[href^="httр://ваппц.ру"] {visibility: hidden}
в итоге все ссылки начинающиеся с ваппц.ру будут скрыты. Так обошли случайно генерируемое окончние ссылки.
Но иногда и окончание ссылки играет роль. К примеру вы хотите выделить все ссылки с доменом.ru зеленым, а.соm красным:
[атрибут$="значение"] {... }
Аналогично ^, с той разницей, что здесь атрибут должен заканчиваться указанным значением, то есть.ru или.соm
В итоге:
a[href$=".ru"] {color:green}

[атрибут*="значение"] {... }
Такая запись показывает, что значение может встречаться в любом месте атрибута, необязательно вначале или в конце.
Правда с масками, типа *^$ браузеры работают не все. Опера 4.2 работает, а вот остальные не уверен. С абсолютом (как в примере с хомяком) работают большинство, а вот с масками... Ну да применение всё равно найти можно.

Вот собсно и всё))
Еще раз пардон за плохое оформление, не было времени более четко обьяснять, да и не смог бы. Но кто хоть более-менее знаком с css - поймет суть. Задавайте вопросы по теме, коль знаю -обьясню.
px Пикселы

cm Сантиметры

mm Миллиметры

pt Пункты (типограф.)

% Проценты
Облако тегов / Авторы