Проблемы с использованием отрицательного поля в фоновых изображениях для отображения маркеров (IE6 и 7) - PullRequest
1 голос
/ 24 февраля 2012

Предметом здесь является использование отрицательных полей в маркированных списках для отображения изображения в желобе слева от элемента заголовка: я нашел статью Simplebits , которая объясняет, почему это хорошее решение длязаголовки (обычно они используются для перемещения столбцов, которые вообще не имеют таких же последствий): комментарии в статье также заслуживают рассмотрения, так как они относятся к проблеме IE, которую это вызывает, хотя решения не предлагается.

В своем первоначальном виде стиль использует URL-адреса данных (которые IE6 / 7 вообще не поддерживает), поэтому я применяю два стиля одновременно: один для современных браузеров, а другой предназначен только для IE6 / 7., используя lt-ie8 класс :

1.CSS для современных браузеров


/* IE6/7 dont display the data URL. In modern browsers this works fine. */

.linked-list-item {
    background: url() no-repeat 0 4px;
    padding-left: 25px;
    margin-left: -25px
}

Это то, что отображает код (оно отображает изображение с полями - обратите внимание на верхнее поле размером 26 пикселей для заголовка «Последние твиты» под ним ):

The standard code for modern browsers displays correctly

2.Только CSS для IE6 / 7


/*   1.   IE6 clips this if you don't add 'float:left' and 'position:relative'
 *
 *   2. { Needed to display the background
 *   3. { image in IE6 [see this thread: http://i.via.dj/EThi]. */

.lt-ie8 .linked-list-item {
    background: url(link-icon-black-16x16.jpg) no-repeat 0 2px;
    padding-left: 25px;
    margin-left: -25px;   /* 1. */
    float: left;   /* 2. */
    position: relative   /* 3. */
}

Отображает изображение маркера ( после добавления float: left и position: relative), но поле длязаголовок h2 сместился вправо до совпадения с маркированным заголовком :

The float in the IE style causes elements to overlap

Первый набор кода (для современных браузеров) работает хорошо, хотя мне интересно, используется литакой большой URL-адрес данных на самом деле стоит того, чтобы избежать лишнего http-запроса, но здесь проблема не в этом.

В исходном виде (без добавления float: left и position: relative) IE-специальная разметка не работает: IE6 обрезает часть элемента, которая находится внутри отрицательного поля, то есть он не отображает маркер изображения, которое он должен отображать.

Это переполнение стека поток фактически предлагает переместить элемент, который обрезается влево, и добавить position: relative.

. Вы можете увидеть HTML и CSS с приведенным выше кодом только для IE, в действии в this jsfiddle .Вы также можете увидеть сайт с песочницей в действии по этой ссылке : попробуйте его в IE6 и 7, и вы увидите следующие проблемы:

1.В IE7 поле для элемента ниже свернуто и перекрывается с маркированным элементом, но это еще хуже, поскольку браузер, похоже, смущен шириной маркированного заголовка:

The result in IE6

2.В IE6 это немного лучше, хотя маржа также уменьшилась:

The result in IE6

Я неохотно обращаюсь к этому с дополнительной разметкой, поскольку это было бы излишним решениемпроблема IE6 / 7, затрагивающая стилизацию CSS, которая нацелена только на очень мало посетителей (так как здесь я собираюсь доставить немало хлопот, чтобы обслужить бедных людей, которые используют эти браузеры…)

Все ещевсе комбинации, которые я мог придумать с overflow, clear, display и т. д., просто не сработали, и поиск этой проблемы в основном вызывает проблемы со столбцами, которые на самом деле совсем не совпадают.

Любые предложения приветствуются, как всегда.

Ответы [ 2 ]

1 голос
/ 24 февраля 2012

ОК, я нашел решение - используйте left вместо margin-left (конечно, с отрицательным значением, конечно… Это устраняет необходимость плавать маркированный элемент, решая проблему сжимающейся маржи.

Вот фиксированный CSS:


.linked-list-item {
    background: url(http://cdn.donaldjenkins.com/media/icons/bullets/link-icon-black-16x16.jpg) no-repeat 0 2px;
    padding-left: 25px;
    left: -25px; /* IE6/7 position the element wrongly if you don't add 'position:relative' */
    position: relative;
}

И вот что это приводит к IE6:

The fix in IE6

IE7 выглядит так же:

The fix in IE7

Как вы можете видеть, поле в 26px для элемента ниже маркированного заголовка появилось снова. Любой, кто неЯ не хочу идти на те же крайности, что и я, и ему не нужны URL-адреса данных, которые могут использовать этот код везде - он работает и в современных браузерах.


Редактировать 26 февраля 2012 г .: Запускстиль маркера, основанный на URL-адресе данных, для современных браузеров рядом с приведенным выше кодом, как я делал на моем сайте , потребовал, чтобы я добавил следующие два атрибута в приведенный выше код, чтобы у меня было два наборакода, работающего параллельно:



<!-- 1. Modern browsers -->

.linked-list-item {
    background:url(data:image/png;base64[…morecode]) no-repeat 0 4px;
    padding-left:25px;
    margin-left:-25px
}

<!-- 2. Targets IE6/7 only -->

.lt-ie8 .linked-list-item {
    background: url(http://cdn.donaldjenkins.com/media/icons/bullets/link-icon-black-16x16.jpg) no-repeat 0 2px;
    padding-left: 25px;
    left: -25px; /* IE6/7 position the element wrongly if you don't add 'position:relative' */
    position: relative;

<!-- a. Ensures background image is always visible in IE6 -->
    height: 100%;

<!-- b. Offsets the -25px negative margin in the modern browsers code -->
    margin-left: 0;
}

1 голос
/ 24 февраля 2012

При кодировании css для старых исследователей, когда вы пишете float:whatever, сразу же добавьте display:inline, это исправит некоторые проблемы с полями. Однако я не знаю, поможет ли это вашей конкретной проблеме.

Вы можете предотвратить сжатие полей, используя верхний / нижний отступ / белую рамку размером 1 пиксель.

Возможно, вы могли бы поиграть с контекстами форматирования блока:

overflow: hidden;
zoom: 1;
position: relative;

Не должно ли h2.sidebar-title иметь clear: both для отключения помехи h2.linked-list-item?

...