Как сохранить: активный стиль css после нажатия элемента

Я использую якорь в качестве навигации по сайту.

 

CSS

 #nav { margin-left: 50px; margin-top: 50px; text-transform: uppercase; } .navitem { background: #333; color: white; width: 230px; height: 50px; font-size: 25px; line-height: 50px; padding-left: 20px; -webkit-user-select: none; -moz-user-select: none; user-select: none; margin-top: 10px; } .about:hover { background: #cc00ff; } .about:active { background: #ff00ff; color: #000; width: 250px; } .works:hover { background: #0066FF; } .works:active { background: #0099cc; color: #000; width: 250px; } 

Мне интересно, как сохранить стиль элемента div в активном состоянии один раз после щелчка, пока я не нажму на другой элемент навигационной панели, и как это сделать?

Объединение JS & CSS:

 button{ /* 1st state */ } button:hover{ /* hover state */ } button:active{ /* click state */ } button.active{ /* after click state */ } jQuery('button').click(function(){ jQuery(this).toggleClass('active'); }); 

Селектор :target -pseudo сделан для таких ситуаций: http://reference.sitepoint.com/css/pseudoclass-target

Он поддерживается всеми современными браузерами. Чтобы получить некоторые версии IE, чтобы понять это, вы можете использовать что-то вроде Selectivizr

Ниже приведен пример вкладок :target -pseudo selector.

Вы можете использовать немного Javascript для добавления и удаления classов CSS ваших навигационных элементов. Для начала создайте class CSS, который вы собираетесь применить к активному элементу, назовите его: «.activeItem». Затем добавьте функцию javascript для каждого из кнопок навигации onclick, которое добавит class activeItem к активированному и удалит из других …

Он должен выглядеть примерно так: (непроверенный!)

 /*In your stylesheet*/ .activeItem{ background-color:#999; /*make some difference for the active item here */ } /*In your javascript*/ var prevItem = null; function activateItem(t){ if(prevItem != null){ prevItem.className = prevItem.className.replace(/{\b}?activeItem/, ""); } t.className += " activeItem"; prevItem = t; }   

Я ПОНЯЛ. ПРОСТОЙ , ЭФФЕКТИВНЫЙ NO jQUERY

Мы собираемся использовать скрытый флажок.
Этот пример включает в себя один «щелчок мышью», зависающий / активный «состояние»,

Чтобы сделать сам контент кликабельным:

HTML

   

CSS

 #activate-div{display:none} .my-div{background-color:#FFF} #activate-div:checked ~ label .my-div{background-color:#000} 

Чтобы изменить содержание кнопки:

HTML

  
//MY DIV CONTENT

CSS

 #activate-div{display:none} .my-div{background-color:#FFF} #activate-div:checked + .my-div{background-color:#000} 

Надеюсь, поможет!!

Если вы хотите, чтобы ваши ссылки выглядели так :active class, вы должны определить :visited class такой же, как :active поэтому, если у вас есть ссылки в .example вы делаете что-то вроде этого:

 a.example:active, a.example:visited { /* Put your active state style code here */ } 

Связанный канал Pseudo Class используется для выбора посещенных ссылок, как указано имя.

  • Использование jQuery для программного перехода по ссылке
  • Scrapy: Следуйте ссылке, чтобы получить дополнительные данные элемента?
  • Как создать прямую ссылку на любую коробку fancybox
  • Как сделать кнопку похожим на ссылку?
  • jQuery отключить ссылку
  • Как ссылаться на метод в javadoc?
  • Может ли Google Chrome открывать локальные ссылки?
  • Как создать ссылки в текстовом клиенте?
  • Interesting Posts

    Результаты поиска Google – получение фактических ссылок

    Метод android finish () не очищает приложение из памяти

    Ошибка обновления 10-летней версии Windows 0xc1900101 – 0x30018, ссылаясь на SYSPREP

    Content-Disposition: Каковы различия между «inline» и «attachment»?

    Как добавить MouseListener в элемент на Java Swing Canvas

    Сохранение и извлечение изображения (двоичного) из SQL Server с использованием Entity Framework 6

    Селектор атрибутов jQuery для нескольких значений

    VBA Excel 2007 помогает ускорить код, чтобы скрыть строки

    Не являются ли строки Python неизменяемыми? Тогда почему работает + “” + b?

    Разница MySQL между двумя строками оператора SELECT

    Как закрыть все фоновые процессы в unix?

    Не удается найти шаблон модели данных Entity Data ADO.net в VS2017

    Получение текста внутри элемента без исключений

    Отобразить изображение на 50% от его «родного» размера

    Можно ли перечислить имена файлов (или их родительские каталоги), которые были недавно удалены с помощью rm в OS X?

    Давайте будем гением компьютера.