Как убрать стрелку из выбранного элемента в Firefox


172

Я пытаюсь стилизовать selectэлемент с помощью CSS3. Я получаю желаемые результаты в WebKit (Chrome / Safari), но Firefox играет не очень хорошо (я даже не беспокоюсь о IE). Я использую appearanceсвойство CSS3 , но по какой-то причине я не могу выкинуть выпадающий значок из Firefox.

Вот пример того, что я делаю: http://jsbin.com/aniyu4/2/edit

#dropdown {
 -moz-appearance: none;
 -webkit-appearance: none;
 appearance: none;
 background: transparent url('example.png') no-repeat right center;
 padding: 2px 30px 2px 2px;
 border: none;
}

Как видите, я не пытаюсь сделать что-то необычное. Я просто хочу удалить стили по умолчанию и добавить собственную стрелку раскрывающегося списка. Как я уже сказал, отлично подходит для WebKit, не очень хорошо для Firefox. По-видимому, -moz-appearance: noneне избавиться от выпадающего элемента.

Любые идеи? Нет, JavaScript не вариант


3
Сейчас есть сообщение об ошибке: bugzilla.mozilla.org/show_bug.cgi?id=649849
sneilan

3
Chosen - это библиотека JavaScript, которая стилизует выбранные вами элементы и делает их действительно красивыми. Возможно, стоит разобраться, хотя это, вероятно, не решит вашу проблему.
stephenmurdoch

Вы можете найти этот пост полезным: red-team-design.com/making-html-dropdowns-not-suck
Руи Маркиз

1
Похоже, они добавили -moz-appearanceсвойство CSS3, которое я использую, -moz-appearance: none;и похоже, что оно работает в версии 35.0.1.
Тони М,

Простым решением было бы сделать элемент select шире контейнера. И оберните URL-префикс Mozilla, чтобы в Firefox параметры были только шире. @-moz-document url-prefix() { select { width: 105%; overflow: hidden; } }
Люк Фемур

Ответы:


78

Хорошо, я знаю, что этот вопрос старый, но 2 года спустя и Mozilla ничего не сделали.

Я придумал простой обходной путь.

По сути, это удаляет все форматирование поля выбора в Firefox и оборачивает элемент span вокруг поля выбора с вашим собственным стилем, но должно применяться только к Firefox.

Скажите, что это ваше меню выбора:

<select class='css-select'>
  <option value='1'> First option </option>
  <option value='2'> Second option </option>
</select>

И давайте предположим, что класс css 'css-select' имеет вид:

.css-select {
   background-image: url('images/select_arrow.gif');
   background-repeat: no-repeat;
   background-position: right center;
   padding-right: 20px;
}

В Firefox это будет отображаться вместе с меню выбора, за которым следует уродливая стрелка выбора Firefox, за которой следует ваша симпатичная стрелка. Не идеально.

Теперь, чтобы запустить это в Firefox, добавьте элемент span с классом 'css-select-moz':

   <span class='css-select-moz'>
     <select class='css-select'>
       <option value='1'> First option </option>
       <option value='2'> Second option </option>
     </select>
   </span>

Затем исправьте CSS, чтобы скрыть грязную стрелку mozilla с помощью -moz-creation: window, и добавьте пользовательскую стрелку в класс диапазона «css-select-moz», но только для отображения на mozilla, например:

.css-select {
   -moz-appearance:window;
   background-image: url('images/select_arrow.gif');
   background-repeat: no-repeat;
   background-position: right center;
   padding-right: 20px;
}

@-moz-document url-prefix() {
.css-select-moz{
     background-image: url('images/select_arrow.gif');
     background-repeat: no-repeat;
     background-position: right center;
     padding-right: 20px;
  }
} 

Довольно круто, что я наткнулся только на эту ошибку 3 часа назад (я новичок в веб-дизайне и полностью самоучка). Однако, это сообщество косвенно оказало мне такую ​​большую помощь, я думал, что пришло время вернуть что-то.

Я только протестировал его в Firefox (Mac) версии 18, а затем 22 (после того, как я обновил).

Все отзывы приветствуются.


2
И через 2 года это лучший ответ, который был опубликован для достижения желаемого результата. Я поместил JSBin кода здесь: jsbin.com/aniyu4/2440/edit для просмотра другими пользователями и сделал только 1 незначительное обновление CSS. Интервал был шире, чем выбранный в FF, из-за правильного заполнения - это означало, что нажатие стрелки не активировало выпадающий список. Чтобы приспособиться к этому, я поместил отрицательное правое поле на элемент select, чтобы вернуть ширину диапазона, чтобы перекрыть ширину select.
РасселУрести

О Конечно! Большое спасибо, Рассел. Очень рад, что это помогло.
Джордан Янг

5
У меня не работал FF 23-24 в Windows (я попробовал jsbin в комментарии). Завершено с помощью этого временного решения stackoverflow.com/questions/6787667/…
Esteban

4
Это не работает на FF 30 больше. Пожалуйста, отправьте заявку на веб-сайт Mozilla: bugzilla.mozilla.org/show_bug.cgi?id=649849 . Чем больше людей жалуются на это, тем больше у нас шансов, что они это исправят.
Стен

1
Работает только на FF 31 на Mac.
Эрвин Вессельс

165

Обновление: это было исправлено в Firefox v35. Смотрите полную суть для деталей.


Просто разобрался, как убрать стрелку выбора из Firefox . Хитрость заключается в том, чтобы использовать смесь -prefix-appearance, text-indentи text-overflow. Это чистый CSS и не требует дополнительной разметки.

select {
    -moz-appearance: none;
    text-indent: 0.01px;
    text-overflow: '';
}

Протестировано на Windows 8, Ubuntu и Mac, последних версиях Firefox.

Живой пример: http://jsfiddle.net/joaocunha/RUEbp/1/

Больше по теме: https://gist.github.com/joaocunha/6273016


1
У меня в моем холодном сердце особое место для таких хакерских исправлений. Это довольно блестяще. Единственным недостатком является то, что FF оставляет пробел в конце выпадающего текстового поля (между фактическим текстом и концом поля выбора), что создает несовместимый интервал между FF и другими браузерами, но это лишь незначительная ошибка. Хорошая находка.
RussellUresti

Хороший улов, @RussellUresti. Но, учитывая, что идея может заключаться в предоставлении измененной стрелки, пространство на самом деле оказывается полезным. Я немного поиграл с ним, и добавил padding-right:10px;к <select>завещанию «толкнуть» теперь невидимую стрелку слева. Итог: Firefox прячет стрелу, Chrome удаляет ее. Буду обновлять мои записи соответственно, спасибо за это.
Жоау Кунья

В качестве ответа я добавил немного кроссбраузера (не проверял в старых версиях IE), чтобы вы могли обновить свой
Даниэль Тулп

2
Лучшее решение для меня, так как -moz-appearence: windowне работает с прозрачным фоном (нарисуйте некрасивую страницу, по крайней мере, на Firefox Linux)
kik

Поскольку это полностью удаляет стрелку, результирующий <select> выглядит как текстовое поле, и это довольно некрасиво. Таким образом, вы можете добавить фоновое изображение обратно, чтобы оно выглядело как раскрывающийся список
thom_nic

59

Уловка, которая работает для меня, состоит в том, чтобы сделать ширину выделения более 100% и применить переполнение: скрытый

select {
    overflow:hidden;
    width: 120%;
}

Это единственный способ скрыть стрелку раскрывающегося списка в FF.

КСТАТИ. если вы хотите красивые выпадающие списки, используйте http://harvesthq.github.com/chosen/


6
Это не имеет никакого эффекта для меня. FF 6.0.2
Чарли Шлиссер

1
Хорошее решение для IE. В моем решении я установил переполнение содержащего элемента div: hidden, а затем увеличил ширину выделения. Прекрасно работает.
Майк

@Charlie S: попытайтесь поместить переполнение: скрытое в содержащий div. Это работает для меня с taht
PierrOz

1
при раскрытии выпадающего меню переполнение: скрытое не работает
Marc

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

26

Важное обновление:

Начиная с Firefox V35 свойство внешнего вида теперь работает !!

Из официальных заметок о выпуске Firefox на V35 :

Использование -moz-appearanceсо noneзначением в выпадающем списке теперь убирает выпадающую кнопку (ошибка 649849).

Так что теперь, чтобы скрыть стрелку по умолчанию - это так же просто, как добавить следующие правила для нашего элемента select:

select {
   -webkit-appearance: none;
   -moz-appearance: none;
   appearance: none;
}

DEMO

select {
  margin: 50px;
  border: 1px solid #111;
  background: transparent;
  width: 150px;
  padding: 5px;
  font-size: 16px;
  border: 1px solid #ccc;
  height: 34px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
<select>
  <option>Apples</option>
  <option selected>Pineapples</option>
  <option>Chocklate</option>
  <option>Pancakes</option>
</select>


20

Мы нашли простой и достойный способ сделать это. Это кросс-браузер, разлагаемый и не нарушает форму сообщения. Сначала установите флажок выбора opacityв 0.

.select { 
    opacity : 0;
    width: 200px;
    height: 15px;
}

<select class='select'>
    <option value='foo'>bar</option>    
</select>

это так, что вы все еще можете нажать на него

Затем сделайте div с теми же размерами, что и поле выбора. Div должен лежать под окном выбора в качестве фона. Используйте { position: absolute }и z-indexдля этого.

.div {
    width: 200px;
    height: 15px;
    position: absolute;
    z-index: 0;
}

<div class='.div'>{the text of the the current selection updated by javascript}</div>
<select class='select'>
    <option value='foo'>bar</option>    
</select>

Обновите div div innerHTML с помощью JavaScript. Easypeasy с помощью jQuery:

$('.select').click(function(event)) { 
    $('.div').html($('.select option:selected').val());
}

Это оно! Просто стиль вашего div вместо поля выбора. Я не тестировал приведенный выше код, поэтому вам, возможно, понадобится настроить его. Но, надеюсь, вы понимаете суть.

Я думаю, что это решение бьет {-webkit-appearance: none;}. То, что браузеры должны делать в лучшем случае, это диктовать взаимодействие с элементами формы, но определенно не то, как они изначально отображаются на странице, поскольку это нарушает дизайн сайта.


6
Это не плохое решение, и оно похоже на шаблон, который я видел для стилизации элемента ввода загрузки файла, но есть несколько недостатков. Во-первых, он опирается на JS, что не идеально. Во-вторых, если в форме есть кнопка сброса, вам необходимо также включить эту функцию в сценарий (сейчас JS только прослушивает щелчок для элемента select, но не отвечает на событие form.reset). Замена элемента select на div будет работать, но в идеале мы могли бы просто стилизовать внешний вид элементов формы. Есть также проблемы доступности, связанные как с JS, так и с поведением форм по умолчанию.
RussellUresti

14

Попробуйте так:

-webkit-appearance: button;
-moz-appearance: button;

Затем вы можете использовать другое изображение в качестве фона и разместить его:

background-image: url(images/select-arrow.png);
background-position: center right;
background-repeat: no-repeat;

Есть еще один способ для браузеров Moz:

text-indent:10px;

Если у вас есть определенная ширина, которую вы выбираете, это свойство будет нажимать кнопку раскрывающегося списка по умолчанию под областью выбора.

Меня устраивает! ;)


6

Хотя это и не полное решение, я обнаружил, что ...

-moz-appearance: window;

... работает в некоторой степени. Вы не можете изменить фон (-color или -image), но элемент можно сделать невидимым с помощью color: transparent. Не идеально, но это начало, и вам не нужно заменять элемент системного уровня на элемент js.


Да, я заметил, что это windowимело эффект, к сожалению, мне нужно было установить фоновое изображение. К сожалению, это не очень хорошо в Firefox.
RussellUresti

К сожалению, вы не можете применить полный сброс к элементам формы, да. Вы всегда можете подделать фон, имея элемент под <select>, что, конечно, не идеально.
Стюарт Бадминтон

1
Это идеально подходит для печати! Просто установите media="print"блок css select {-moz-appearance: window;}и удалите стрелки и фоны всех выделений в FF (для других браузеров попробуйте внешний вид или -webkit-появление), чтобы они выглядели как обычный текст или заголовки
FrancescoMM

4

Я думаю, что нашел решение, совместимое с FF31 !!!
Вот два варианта, которые хорошо объяснены по этой ссылке:
http://www.currelis.com/hiding-select-arrow-firefox-30.html

Я использовал вариант 1: Родриго-Луджеро опубликовал это исправление на Github, включая онлайн демо. Я протестировал эту демонстрацию на Firefox 31.0, и она, кажется, работает правильно. Проверено на Chrome и IE. Вот HTML-код:

<!DOCTYPE html>
<html>
    <head>
    <meta charset="utf-8">
    <title>Custom Select</title>
    <link href="http://netdna.bootstrapcdn.com/font-awesome/4.0.3/css/font-awesome.min.css" rel="stylesheet" type="text/css" />
    </head>
    <body>
        <div class="custom-select fa-caret-down">
            <select name="" id="">
                <option value="">Custom Select</option>
                <option value="">Custom Select</option>
                <option value="">Custom Select</option>
            </select>
        </div>
    </body>
</html>

и CSS:

.custom-select {
    background-color: #fff;
    border: 1px solid #ccc;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    margin: 0 0 2em;
    padding: 0;
    position: relative;
    width: 100%;
    z-index: 1;
}

.custom-select:hover {
    border-color: #999;
}

.custom-select:before {
    color: #333;
    display: block;
    font-family: 'FontAwesome';
    font-size: 1em;
    height: 100%;
    line-height: 2.5em;
    padding: 0 0.625em;
    position: absolute;
    top: 0;
    right: 0;
    text-align: center;
    width: 1em;
    z-index: -1;
}

.custom-select select {
    background-color: transparent;
    border: 0 none;
    box-shadow: none;
    color: #333;
    display: block;
    font-size: 100%;
    line-height: normal;
    margin: 0;
    padding: .5em;
    width: 100%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.custom-select select::-ms-expand {
    display: none; /* to ie 10 */
}

.custom-select select:focus {
    outline: none;
}
/* little trick for custom select elements in mozilla firefox  17/06/2014 @rodrigoludgero */
:-moz-any(.custom-select):before {
    background-color: #fff; /* this is necessary for overcome the caret default browser */
    pointer-events: none; 
    z-index: 1; /* this is necessary for overcome the pseudo element */
}

http://jsbin.com/pozomu/4/edit

Это очень хорошо работает для меня!


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

Спасибо за подсказки! Извините за мои ошибки!
ferocesalatino

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

2

К сожалению для вас это является «что - то фантазии». Обычно это не место для авторов веб-сайтов, чтобы перепроектировать элементы формы. Многие браузеры нарочно не позволяют вам стилизовать их, чтобы пользователь мог видеть элементы управления ОС, к которым он привык.

Единственный способ сделать это последовательно через браузеры и операционные системы, это использовать JavaScript и заменить select элементы на «DHTML».

В следующей статье показаны три плагина на основе jQuery, которые позволяют вам это делать (он немного староват, но сейчас я не могу найти ничего актуального)

http://www.queness.com/post/204/25-jquery-plugins-that-enhance-and-beautify-html-form-elements#1


8
Я не согласен с тем, что это что-то необычное, хотя экспериментальное. Весь смысл этого appearanceсвойства в том, чтобы дать разработчикам контроль над внешним видом элементов формы, потому что использование JavaScript для этого является ужасным решением. Браузеры не должны принимать решение о том, как что-то выглядит на странице - это решение UX, а не решение поставщика браузера. К сожалению, пока что это не очень хорошо поддерживается. Может быть, в другой год.
RussellUresti

Я не считаю «причудливым», если я хочу, чтобы при печати страницы все выделения выглядели как поле без стрелок. И это должен быть мой выбор, а не браузер или выбор ОС. У меня есть выбор с месяцами, и когда страница печатается, у меня есть специальный CSS для печати, который удаляет стрелку на напечатанной странице, так что она выглядит как заголовок «Март» без стрелок, которые не имеют смысла на напечатанной странице.
FrancescoMM

2
/* Try this in FF30+ Covers up the arrow, turns off the background */ 
/* still lets you style the border around the image and allows selection on the arrow */


@-moz-document url-prefix() {

    .yourClass select {
        text-overflow: '';
        text-indent: -1px;
        -moz-appearance: none;
        background: none;

    }

    /*fix for popup in FF30 */
    .yourClass:after {
        position: absolute;
        margin-left: -27px;
        height: 22px;
        border-top-right-radius: 6px;
        border-bottom-right-radius: 6px;
        content: url('../images/yourArrow.svg');
        pointer-events: none;
        overflow: hidden;
        border-right: 1px solid #yourBorderColour;
        border-top: 1px solid #yourBorderColour;
        border-bottom: 1px solid #yourBorderColour; 
    }
}

+20 за предложение использовать псевдоэлемент
Зак Сауцер

2

Мне нравится этот стиль

<select style="     -moz-appearance: radio-container;
                -webkit-appearance: none;
                 appearance: none;
">

Это работает для меня в FF, Safari и Chrome во всех версиях, которые я тестировал.

В IE я положил:

 select::-ms-expand {
 display: none;
}
/*to remove in all selects*/

Также вы можете: .yourclass :: - ms-expand {display: none; } .yourid :: - ms-exapan {display: none; }


1

Я знаю, что этот вопрос немного старый, но так как он появляется в Google, и это «новое» решение:

appearance: normalКажется, работает нормально в Firefox для меня (версия 5 сейчас). но не в опере и IE8 / 9

В качестве обходного пути для Opera и IE9 я использовал :before псевдоселектор для создания нового белого поля и поместил его поверх стрелки.

К сожалению, в IE8 это не работает. Поле отображается правильно, но стрелка все равно торчит ...: - /

Использование select:beforeпрекрасно работает в Opera, но не в IE. Если я смотрю на инструменты разработчика, я вижу, что они правильно читают правила, а затем просто игнорируют их (они вычеркнуты). Поэтому я использую <span class="selectwrap">вокруг фактического <select>.

select {
  -webkit-appearance: normal;
  -moz-appearance: normal;
  appearance: normal;
}
.selectwrap { position: relative; }
.selectwrap:before {
  content: "";
  height: 0;
  width: 0;
  border: .9em solid red;
  background-color: red;
  position: absolute;
  right: -.1em;
  z-index: 42;
}

Возможно, вам придется немного подправить это, но это работает для меня!

Отказ от ответственности: я использую это, чтобы получить красивую печатную копию веб-страницы с формами, поэтому мне не нужно создавать вторую страницу. Я не 1337 haxx0r, который хочет красные полосы прокрутки, <marquee>теги и еще много чего :-). Пожалуйста , не применяйте чрезмерную стилизацию к формам, если у вас нет веских причин.


3
-moz-appearance: normalне кажется допустимым в Fx 9, и -moz-appearance: none(который действителен) не удаляет стрелку вниз.
Робин Уинслоу

Ваше решение с перекрывающимся диапазоном работает в IE и FF, но не работает в Chrome.
вулкан ворон

: before и: after псевдоэлементы работают только с элементами, которые принимают внутренний контент. Это не относится к селекту, ни к входу, ни к загрузчику файлов и т. Д. Они отлично подходят для div, ссылок, абзацев и т. Д. Причина в том, что они добавляют контент не до / после самого ЭЛЕМЕНТА, а до ЭТОГО СОДЕРЖАНИЕ. И элемент select не поддерживает что-то подобное <select> hi.
Жоау Кунья

1

Используйте pointer-eventsсобственность.

Идея состоит в том, чтобы наложить элемент на собственную стрелку раскрывающегося списка (чтобы создать нашу собственную), а затем запретить указатель на него. [см. этот пост ]

Вот рабочая скрипка использующая этот метод.

Кроме того, в этом SO ответе я обсудил этот и другой метод более подробно.


1

Это работает (проверено на Firefox 23.0.1):

select {
    -moz-appearance: radio-container;
}

Работал на меня, но мне не нравилось radio-containerзначение для выбранного объекта. Просмотрите ссылку mozilla -moz-Appearance, чтобы получить соответствующее значение (я использовал, menulist-textкоторый скрывает стрелку выбора в FF 31)
sglessard

1

опираясь на ответ @ JoãoCunha, один стиль CSS, который полезен для более чем одного браузера

select {
    /*for firefox*/
    -moz-appearance: none;
    /*for chrome*/
    -webkit-appearance:none;
    text-indent: 0.01px;
    text-overflow: '';
}
/*for IE10*/
select::-ms-expand {
    display: none;
}

1

В дополнение к ответу Joao Cunha , эта проблема в настоящее время включена в список дел Mozilla и предназначена для версии 35.

Для тех, кто желает, вот обходной путь Тодда Паркера, на который ссылается блог Куньи, который работает сегодня:

http://jsfiddle.net/xvushd7x/

HTML:

<label class="wrapper">This label wraps the select
    <div class="button custom-select ff-hack">
        <select>
            <option>Apples</option>
            <option>Bananas</option>
            <option>Grapes</option>
            <option>Oranges</option>
            <option>A very long option name to test wrapping</option>
        </select>
    </div>
</label>

CSS:

/* Label styles: style as needed */
label {
  display:block;
  margin-top:2em;
  font-size: 0.9em;
  color:#777;
}

/* Container used for styling the custom select, the buttom class below adds the bg gradient, corners, etc. */
.custom-select {
  position: relative;
  display:block;
  margin-top:0.5em;
  padding:0;
}

/* These are the "theme" styles for our button applied via separate button class, style as you like */
.button {
  border: 1px solid #bbb;
  border-radius: .3em;
  box-shadow: 0 1px 0 1px rgba(0,0,0,.04);
  background: #f3f3f3; /* Old browsers */
  background: -moz-linear-gradient(top, #ffffff 0%, #e5e5e5 100%); /* FF3.6+ */
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(100%,#e5e5e5)); /* Chrome,Safari4+ */
  background: -webkit-linear-gradient(top, #ffffff 0%,#e5e5e5 100%); /* Chrome10+,Safari5.1+ */
  background: -o-linear-gradient(top, #ffffff 0%,#e5e5e5 100%); /* Opera 11.10+ */
  background: -ms-linear-gradient(top, #ffffff 0%,#e5e5e5 100%); /* IE10+ */
  background: linear-gradient(to bottom, #ffffff 0%,#e5e5e5 100%); /* W3C */
}

/* This is the native select, we're making everything but the text invisible so we can see the button styles in the wrapper */
.custom-select select {
  width:100%;
  margin:0;
  background:none;
  border: 1px solid transparent;
  outline: none;
  /* Prefixed box-sizing rules necessary for older browsers */
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  /* Remove select styling */
  appearance: none;
  -webkit-appearance: none;
  /* Font size must the 16px or larger to prevent iOS page zoom on focus */
  font-size:16px;
  /* General select styles: change as needed */
  font-family: helvetica, sans-serif;
  font-weight: bold;
  color: #444;
  padding: .6em 1.9em .5em .8em;
  line-height:1.3;
}


/* Custom arrow sits on top of the select - could be an image, SVG, icon font, etc. or the arrow could just baked into the bg image on the select. Note this si a 2x image so it will look bad in browsers that don't support background-size. In production, you'd handle this resolution switch via media query but this is a demo. */

.custom-select::after {
  content: "";
  position: absolute;
  width: 9px;
  height: 8px;
  top: 50%;
  right: 1em;
  margin-top:-4px;
  background-image: url(http://filamentgroup.com/files/select-arrow.png);
  background-repeat: no-repeat;
  background-size: 100%;
  z-index: 2;
  /* These hacks make the select behind the arrow clickable in some browsers */
  pointer-events:none;
}


/* Hover style */
.custom-select:hover {
  border:1px solid #888;
}

/* Focus style */
.custom-select select:focus {
  outline:none;
  box-shadow: 0 0 1px 3px rgba(180,222,250, 1);
  background-color:transparent;
  color: #222;
  border:1px solid #aaa;
}

/* Set options to normal weight */
.custom-select option {
  font-weight:normal;
}

1

С Firefox 35 "-moz-appearance:none », который вы уже написали в своем коде, наконец удалите кнопку со стрелкой, как вам нужно.

Это была ошибка, решенная с этой версии.


1

Много дискуссий происходит здесь и там, но я не вижу правильного решения этой проблемы. Наконец закончилась написанием небольшого кода Jquery + CSS для выполнения этого HACK на IE и Firefox.

Рассчитать ширину элемента (SELECT Element) с помощью Jquery. Добавьте обертку вокруг элемента Select и держите переполнение скрытым для этого элемента. Убедитесь, что ширина этой обертки - appox. На 25 пикселей меньше, чем у элемента SELECT. Это можно легко сделать с помощью Jquery. Так что теперь наша икона ушла ..! и пришло время добавить наш значок изображения на элемент SELECT ... !!! Просто добавьте несколько простых строк для добавления фона, и все готово! Убедитесь, что вы используете переполнение, скрытое для внешней оболочки,

Вот пример кода, который был сделан для Drupal. Однако может быть использован для других, также удалив несколько строк кода, специфичных для Drupal.

/*
 * Jquery Code for Removing Dropdown Arrow.
 * @by: North Web Studio
 */
(function($) {
  Drupal.behaviors.nwsJS = {
    attach: function(context, settings) {
      $('.form-select').once('nws-arrow', function() {
        $wrap_width = $(this).outerWidth();
        $element_width = $wrap_width + 20;
        $(this).css('width', $element_width);
        $(this).wrap('<div class="nws-select"></div>');
        $(this).parent('.nws-select').css('width', $wrap_width);
      });
    }
  };
})(jQuery);
/*
 * CSS Code for Removing Dropdown Arrow.
 * @by: North Web Studio
 */

.nws-select {
  border: 1px solid #ccc;
  overflow: hidden;
  background: url('../images/icon.png') no-repeat 95% 50%;
}
.nws-select .form-select {
  border: none;
  background: transparent;
}

Решение работает на всех браузерах IE, Chrome и Firefox. Не нужно добавлять хаки фиксированной ширины с помощью CSS. Все это обрабатывается динамически с использованием JQuery.

Более подробно описано по адресу: - http://northwebstudio.com/blogs/1/jquery/remove-drop-down-arrow-html-select-element-using-jquery-and-css



0

appearanceСвойство из CSS3 не допускает noneзначения. Взгляните на ссылку W3C . Итак, то, что вы пытаетесь сделать, недопустимо (действительно, Chrome тоже не должен это принимать).

К сожалению, у нас действительно нет кросс-браузерного решения, чтобы скрыть эту стрелку, используя чистый CSS. Как указано, вам понадобится JavaScript.

Я предлагаю вам рассмотреть возможность использования плагина selectBox jQuery . Это очень легко и красиво сделано.


1
Но noneэто значение, которое Firefox утверждает, что поддерживает: developer.mozilla.org/en/CSS/-moz-appearance Хотя в прошлом стилизация элементов формы в прошлом была возможна только через JavaScript, весь смысл этого appearanceсвойства - отойти От этого. Поставщики браузеров не должны принимать решения UX для разработчиков. К сожалению, кажется, что это все еще слишком ново для эффективного использования.
RussellUresti

1
@RussellUresti, поэтому, даже если описание из префикса поставщика -mozпринимает none(даже если это сработало), было бы неправильно использовать его. Еще больше о браузере, таком как Firefox, который всегда хвастался, точно следуя стандартам.
Эрик Петручелли

0

Вы можете увеличить ширину поля и переместить стрелку ближе к левой части стрелки. это тогда позволяет вам покрыть стрелку пустым белым делителем.

Посмотрите: http://jsbin.com/aniyu4/86/edit



0

Или вы можете закрепить выбор. Что-то вроде:

select { width:200px; position:absolute; clip:rect(0, 170px, 50px, 0); }

Это должно обрезать 30px правой стороны поля выбора, убрав стрелку. Теперь добавьте фоновое изображение 170px и вуаля в стиле select


0

Это огромный взлом, но -moz-appearance: menulist-textможет сработать.


Это, похоже, убрало для меня стрелку выбора, но, как заметил @dendini, оно также убрало все другие стили для элемента
codestr

0

У меня была такая же проблема. Легко заставить его работать на FF и Chrome, но на IE (8+, который мы должны поддерживать) все усложняется. Самое простое решение, которое я мог найти для пользовательских элементов select, которые работают «везде, где я пробовал», включая IE8, - это использование .customSelect ()


0

Полезным для меня хаком является установка (выбор) дисплея в inline-flex. Вырезает стрелку прямо из моей кнопки выбора. Без всего добавленного кода.

  • Только для Fx. -webkit appearanceвсе еще нужен для Chrome и т.д ...

2
Кажется, не имеет никакого эффекта
Крис Никола

0

Ответ Джордана Янга самый лучший. Но если вы не можете или не хотите менять свой HTML, вы можете просто удалить пользовательскую стрелку вниз, используемую в Chrome, Safari и т. Д., И оставить стрелку по умолчанию в Firefox, но без двойных стрелок. Не идеально, но хорошее быстрое исправление, которое не добавляет HTML и не ставит под угрозу ваш внешний вид в других браузерах.

<select>
  <option value='1'> First option </option>
  <option value='2'> Second option </option>
</select>

CSS:

select {
   background-image: url('images/select_arrow.gif');
   background-repeat: no-repeat;
   background-position: right center;
   padding-right: 20px;
}

@-moz-document url-prefix() {
  select {
    background-image: none;
  }
}

0

hackity hack ... решение, которое работает во всех протестированных мной браузерах (Safari, Firefox, Chrome). У вас не должно быть никаких IE, поэтому было бы неплохо, если бы вы могли протестировать и прокомментировать:

<div class="wrapper">
  <select>
    <option>123456789</option>
    <option>234567890</option>
  </select>
</div>

CSS, с изображением в кодировке URL:

.wrapper { position:relative; width:200px; }
.wrapper:after {
  content:"";
  display: block;
  position: absolute;
  top:1px; height:28px;
  right:1px; width:16px;
  background-image: url();

  pointer-events: none;
}

select {
  width: 100%;
  padding:3px;
  margin: 0;
  border-radius: 0;
  border:1px solid black;
  outline:none;
  display: inline-block;
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  cursor:pointer;
  float:none!important;
  background:white;

  font-size:13px;
  line-height: 1em;
  height: 30px;
  padding:6px 20px 6px 10px;
}

http://codepen.io/anon/pen/myPEBy

Я использую: after-element, чтобы скрыть уродливую стрелку. Так как select не поддерживает: после, мне нужна оболочка для работы. Теперь, если вы нажмете на стрелку, выпадающий список не зарегистрирует его ... если ваш браузер не поддерживает pointer-events: none, что делают все, кроме IE10: http://caniuse.com/#feat=pointer-events

Так что для меня это идеально - хорошее, чистое решение с низким уровнем головной боли, по крайней мере, по сравнению со всеми другими опциями, которые включают в себя javascript.

ТЛ; др:

Если пользователи IE10 (или ниже) нажмут на стрелку, это не сработает. Работает достаточно хорошо для меня ...


0

Если вы не возражаете возиться с JS, я написал небольшой плагин jQuery, который поможет вам это сделать. С ним вам не нужно беспокоиться о префиксах вендоров.

 $.fn.magicSelectBox = function() {
  var $e = this;

  $e.each(function() {
    var $select = $(this);

    var $magicbox = $('<div></div>').attr('class', $select.attr('class')).attr('style', $select.attr('style')).addClass('magicbox');
    var $innermagicbox = $('<div></div>').css({
      position: 'relative',
      height: '100%'
    });
    var $text = $('<span></span>').css({
      position: 'absolute'
    }).text($select.find("option:selected").text());

    $select.attr('class', null).css({
      width: '100%',
      height: '100%',
      opacity: 0,
      position: 'absolute'
    }).on('change', function() {
      $text.text($select.find("option:selected").text());
    });

    $select.parent().append($magicbox);
    $innermagicbox.append($text, $select);
    $magicbox.append($innermagicbox);
  });

  return $e;
};

Скрипка здесь: JS Fiddle

Условие состоит в том, что вы должны стилизовать выделение с нуля (это означает задание фона и границы), но вы все равно, вероятно, захотите это сделать.

Кроме того, поскольку функция заменяет исходное выделение на div, вы потеряете все стили, сделанные непосредственно в селекторе выбора в вашем CSS. Так что дайте элементу выбора класс и стилизуйте его.

Поддерживает большинство современных браузеров, если вы хотите использовать более старые браузеры, вы можете попробовать более старую версию jQuery, но, возможно, придется заменить on () на bind () в функции (не проверено)


-2

Другие ответы, казалось, не работали для меня, но я нашел этот взлом. Это сработало для меня (июль 2014)

select {
-moz-appearance: textfield !important;
    }

В моем случае у меня также было поле ввода woocommerce, поэтому я использовал это

.woocommerce .quantity input.qty {
-moz-appearance: textfield !important;
 }

Обновил мой ответ, чтобы показать выбор, а не ввод


input.input-text? какое это имеет отношение к опции выбора и заданному вопросу?
Дендини
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.