iPhone iOS не будет правильно отображать тени

Дизайн

Контактная форма в адаптивном дизайне имеет поля ввода как со встроенной тенью, так и с обычной внешней тенью. Смотрите изображение ниже.

Дизайн поля ввода на мобильном устройстве


Код

input {
    background:#fff;
    height:auto;
    padding:8px 8px 7px;
    width:100%;
    box-sizing:border-box;
    -moz-box-sizing:border-box;
    -webkit-box-sizing:border-box;
    border:#fff solid 3px;
    border-radius:4px;
    box-shadow:0px 0px 5px rgba(0, 0, 0, .25), inset 2px 2px 3px rgba(0, 0, 0, .2);
}

Проблема

iOS v4+ не отображает тень блока должным образом. Смотрите изображение ниже.

Поле ввода-тени отображается неправильно


проверенный

Я пытался использовать -webkit-box-shadow.

-webkit-box-shadow:0px 0px 5px rgba(0, 0, 0, .25),
                   inset 2px 2px 3px rgba(0, 0, 0, .2);

Я применил display:block; к элементу ввода.


Текущее решение

Я бы предпочел не делать этого, но это единственный способ получить желаемый эффект.

HTML

<p><input /></p>

CSS

p {
   width:50%;
   box-sizing:border-box;
   -moz-box-sizing:border-box;
   -webkit-box-sizing:border-box;
   box-shadow:0px 0px 5px rgba(0, 0, 0, .35);
   border-radius:4px;
}

    input {
        background:#fff;
        height:auto;
        padding:8px 8px 7px;
        width:100%;
        box-sizing:border-box;
        -moz-box-sizing:border-box;
        -webkit-box-sizing:border-box;
        border:#fff solid 3px;
        border-radius:4px;
        box-shadow:inset 2px 2px 3px rgba(0, 0, 0, .2);
    }

Даже с этим обходным путем тень на iOS не отображается должным образом; но это достаточно близко


Мой вопрос

Можно ли иметь несколько экземпляров box-shadow на одном элементе рендеринга должным образом на устройствах iOS? Если нет, то как насчет тени? Или я неправильно использую это свойство и его значения?

Заранее спасибо!

1 ответ

Решение

Попробуйте добавить -webkit-appearance: none; iOS имеет тенденцию портить формы.

У меня возникла проблема с попыткой добавить тень окна вокруг недопустимых входов (до нажатия кнопки отправки).

С помощью -webkit-appearance: none; некоторое время работал нормально, но я заметил, что на хромированных флажках сейчас пропали.

Вот мой хак, который работает более или менее кроссбраузерно. Похоже, что safari - это новый "Internet Explorer":-/

input:invalid, select:invalid, textarea:invalid, .invalid {
    background-clip: padding-box; /* Safari fix */
    box-shadow: 0 0 5pt 2pt rgba(255,0,0,.75) !important;
}

select:invalid {
    border: 1px solid red; /* Safari fix */
}

input[type="checkbox"]:invalid{
    background: red; /* Safari fix */
}

input[type="radio"]:invalid{
    background: red; /* Safari fix */
}

Другие вопросы по тегам