Cara menghapus panah dari elemen pilih di Firefox

172

Saya mencoba gaya selectelemen menggunakan CSS3. Saya mendapatkan hasil yang saya inginkan di WebKit (Chrome / Safari), tetapi Firefox tidak bermain dengan baik (Saya bahkan tidak peduli dengan IE). Saya menggunakan appearanceproperti CSS3 , tetapi untuk beberapa alasan saya tidak dapat menghilangkan ikon drop-down dari Firefox.

Inilah contoh apa yang saya lakukan: 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;
}

Seperti yang Anda lihat, saya tidak mencoba sesuatu yang mewah. Saya hanya ingin menghapus gaya default dan menambahkan panah drop-down saya sendiri. Seperti yang saya katakan, hebat di WebKit, tidak hebat di Firefox. Rupanya, -moz-appearance: nonetidak menghilangkan item drop-down.

Ada ide? Tidak, JavaScript bukan opsi

RussellUresti
sumber
3
Ada laporan bug tentang ini sekarang: bugzilla.mozilla.org/show_bug.cgi?id=649849
sneilan
3
Dipilih adalah pustaka JavaScript yang memberi style pada pilihan Anda untuk Anda dan membuatnya terlihat sangat mewah. Mungkin layak untuk dilihat meskipun mungkin tidak akan menyelesaikan masalah Anda.
stephenmurdoch
Anda mungkin menemukan posting blog ini berguna: red-team-design.com/making-html-dropdowns-not-suck
Rui Marques
1
Sepertinya mereka telah menambahkan -moz-appearanceproperti CSS3, saya menggunakan -moz-appearance: none;dan tampaknya berfungsi di versi 35.0.1.
Tony M
Perbaikan sederhana akan membuat elemen pilih lebih luas dari wadah. Dan bungkus awalan mozilla url sehingga opsinya hanya lebih luas di firefox. @-moz-document url-prefix() { select { width: 105%; overflow: hidden; } }
Luke Femur

Jawaban:

78

Oke, saya tahu pertanyaan ini sudah tua, tetapi 2 tahun ke depan dan mozilla tidak melakukan apa-apa.

Saya telah menemukan solusi sederhana.

Ini pada dasarnya menghapus semua pemformatan kotak pilih di firefox dan membungkus elemen rentang di sekitar kotak pilih dengan gaya khusus Anda, tetapi seharusnya hanya berlaku untuk firefox.

Katakan ini adalah menu pilihan Anda:

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

Dan mari kita asumsikan kelas css 'css-select' adalah:

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

Di firefox, ini akan ditampilkan dengan menu pilih, diikuti oleh panah pilih firefox jelek, diikuti oleh kustom Anda tampak bagus. Tidak ideal

Sekarang untuk menjalankan firefox ini, tambahkan elemen span sekitar dengan kelas '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>

Kemudian perbaiki CSS untuk menyembunyikan panah kotor mozilla dengan -moz-appearance: window dan melempar panah kustom ke kelas span 'css-select-moz', tetapi hanya tampilkan di mozilla, seperti ini:

.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;
  }
} 

Cukup keren untuk hanya menemukan bug ini 3 jam yang lalu (saya baru mengenal desain web dan sepenuhnya otodidak). Namun, komunitas ini secara tidak langsung telah memberi saya banyak bantuan, saya pikir sudah saatnya saya memberikan sesuatu kembali.

Saya hanya mengujinya di firefox (mac) versi 18, dan kemudian 22 (setelah saya perbarui).

Semua umpan balik diterima.

Jordan Young
sumber
2
Dan setelah 2 tahun, ini adalah jawaban terbaik yang telah diposting untuk mencapai hasil yang saya inginkan. Saya telah memasukkan JSBin dari kode di sini: jsbin.com/aniyu4/2440/edit untuk dilihat orang lain, dan hanya membuat 1 pembaruan CSS kecil. Rentang lebih lebar daripada yang dipilih di FF, karena bantalan kanan - ini berarti mengklik panah tidak mengaktifkan dropdown. Untuk menyesuaikan ini, saya telah menempatkan margin kanan negatif pada elemen pilih untuk menarik lebar rentang kembali, untuk tumpang tindih lebar pilih.
RussellUresti
Oh tentu! Terima kasih banyak, Russell. Sangat senang ini membantu.
Jordan Young
5
Tidak bekerja untuk saya di FF 23-24 di Windows (saya mencoba jsbin di komentar). Akhirnya menggunakan solusi ini stackoverflow.com/questions/6787667/…
Esteban
4
Tidak lagi berfungsi pada FF 30. Silakan dan kirimkan tiket di situs web Mozilla: bugzilla.mozilla.org/show_bug.cgi?id=649849 . Semakin banyak orang mengeluh tentang hal itu, semakin besar peluang kita untuk memperbaikinya.
Stan
1
Hanya bekerja pada FF 31 di Mac.
Erwin Wessels
165

Pembaruan: ini diperbaiki di Firefox v35. Lihat inti lengkap untuk detailnya.


Baru tahu cara menghapus panah pilihan dari Firefox . Caranya adalah dengan menggunakan campuran -prefix-appearance, text-indentdan text-overflow. Ini adalah CSS murni dan tidak memerlukan markup tambahan.

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

Diuji pada Windows 8, Ubuntu dan Mac, versi terbaru Firefox.

Contoh langsung: http://jsfiddle.net/joaocunha/RUEbp/1/

Lebih lanjut tentang subjek: https://gist.github.com/joaocunha/6273016

João Cunha
sumber
1
Saya memiliki tempat khusus di hati saya yang biasanya dingin untuk perbaikan seperti ini. Agak brilian. Satu-satunya downside adalah bahwa FF meninggalkan ruang di ujung area teks dropdown (antara teks aktual dan akhir kotak pilih), yang menciptakan jarak yang tidak konsisten antara FF dan browser lainnya, tetapi itu hanya sedikit quibble. Temuan yang bagus.
RussellUresti
Tangkapan yang bagus, @RussellUresti. Tetapi mengingat seluruh ide mungkin untuk menyediakan panah yang dimodifikasi, ruang sebenarnya terbukti berguna. Saya bermain sedikit dengannya, dan menambahkan padding-right:10px;ke <select>"push" panah yang sekarang tidak terlihat ke kiri. Intinya: Firefox menyembunyikan panah, Chrome MENGHAPUS. Akan memperbarui tulisan saya sesuai, terima kasih untuk itu.
João Cunha
Saya menambahkan sedikit crossbrowser (belum diuji dalam versi lama IE) sebagai jawaban sehingga Anda dapat memperbarui milik Anda
Daniël Tulp
2
Solusi terbaik untuk saya, karena -moz-appearence: windowtidak bekerja dengan latar belakang transparan (menggambar bg jelek di tempat, setidaknya di firefox linux)
kik
Karena ini menghapus panah sama sekali, <select> yang dihasilkan terlihat seperti kotak teks dan agak jelek. Jadi Anda dapat menambahkan gambar latar belakang kembali agar terlihat seperti dropdown: codepen.io/anon/pen/nvfCq
thom_nic
59

Trik yang bekerja untuk saya adalah membuat lebar pilih lebih dari 100% dan menerapkan overflow: disembunyikan

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

Ini adalah satu-satunya cara sekarang untuk menyembunyikan panah dropdown di FF.

BTW. jika Anda ingin dropdown yang indah gunakan http://harvesthq.github.com/chosen/

opengrid
sumber
6
Ini tidak berpengaruh bagi saya. FF 6.0.2
Charlie Schliesser
1
Solusi yang bagus untuk IE juga. Dalam solusi saya, saya mengatur elemen div yang mengandung melimpah: disembunyikan dan kemudian membuat lebar pilih lebih besar. Bagus sekali.
Mike
@Charlie S: mencoba untuk meletakkan overflow: disembunyikan di div yang mengandung Ini bekerja untuk saya dengan itu
PierrOz
1
ketika Anda memperluas dropdown, overflow: hidden tidak berfungsi
Marc
Bekerja dengan baik untuk saya. Itu membuat daftar dropdown sedikit lebih lebar dari bit atas tapi itu harga yang saya bayarkan.
Jimbali
26

Pembaruan Penting:

Pada Firefox V35 properti penampilan sekarang berfungsi !!

Dari catatan rilis resmi firefox di V35 :

Menggunakan -moz-appearancedengan nonenilai pada kotak kombo sekarang menghapus tombol dropdown (bug 649849).

Jadi sekarang untuk menyembunyikan panah default - semudah menambahkan aturan berikut pada elemen pilih kami:

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>

Danield
sumber
20

Kami telah menemukan cara sederhana dan layak untuk melakukan ini. Ini lintas-browser, dapat didegradasi, dan tidak memecah posting bentuk. Pertama, atur kotak pilih opacityke 0.

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

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

ini agar Anda masih bisa mengkliknya

Kemudian buat div dengan dimensi yang sama dengan kotak pilih. Div harus diletakkan di bawah kotak pilih sebagai latar belakang. Gunakan { position: absolute }dan z-indexuntuk mencapai ini.

.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>

Perbarui innerHTML div dengan javascript. Mudah dengan jQuery:

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

Itu dia! Cukup gaya div Anda, bukan kotak pilih. Saya belum menguji kode di atas sehingga Anda mungkin perlu mengubahnya. Tapi semoga Anda mendapatkan intinya.

Saya pikir solusi ini berdetak {-webkit-appearance: none;}. Apa yang harus dilakukan browser paling banyak adalah menentukan interaksi dengan elemen formulir, tetapi jelas bukan bagaimana awalnya ditampilkan pada halaman saat itu merusak desain situs.

Shaun
sumber
6
Ini bukan solusi yang buruk, dan mirip dengan pola yang saya lihat untuk menata elemen input unggah file, tetapi ada beberapa kelemahan. Pertama, ini bergantung pada JS, yang tidak ideal. Kedua, jika form memiliki tombol reset, Anda kemudian harus skrip fungsi itu juga (sekarang, JS hanya mendengarkan klik untuk elemen pilih, tetapi tidak menanggapi acara form.reset). Mengganti elemen pilih dengan div akan bekerja, tetapi, idealnya, kita bisa mendesain tampilan elemen bentuk. Ada juga masalah aksesibilitas yang berkaitan dengan perilaku formulir JS dan default.
RussellUresti
14

Coba dengan cara ini:

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

Kemudian, Anda dapat menggunakan gambar yang berbeda sebagai latar belakang dan menempatkannya:

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

Ada cara lain untuk browser moz:

text-indent:10px;

Jika Anda memiliki lebar yang ditentukan untuk Anda pilih, properti ini akan menekan tombol dropbox default di bawah area yang dipilih.

Ini bekerja untuk saya! ;)

ninja_corp
sumber
6

Meskipun bukan solusi lengkap saya telah menemukan bahwa ...

-moz-appearance: window;

... bekerja sampai batas tertentu. Anda tidak dapat mengubah latar belakang (-warna atau -gambar) tetapi elemen tersebut dapat ditampilkan dengan warna: transparan. Tidak sempurna tapi ini awal dan Anda tidak perlu mengganti elemen tingkat sistem dengan js satu.

Stuart Badminton
sumber
Ya, saya perhatikan bahwa windowada efeknya, sayangnya, saya perlu mengatur gambar latar belakang. Sangat disayangkan bahwa ini tidak terlalu baik di Firefox.
RussellUresti
Sangat disayangkan bahwa Anda tidak dapat menerapkan setel ulang penuh untuk membentuk elemen, ya. Anda selalu dapat memalsukan latar belakang dengan memiliki elemen di bawah <select>, yang tentu saja tidak ideal.
Stuart Badminton
1
Ini SEMPURNA untuk dicetak! Cukup setel media="print"blok css dengan select {-moz-appearance: window;}dan akan menghapus panah dan latar belakang dari semua pilihan pada FF (untuk browser lain coba penampilan atau -webkit-penampilan) sehingga mereka terlihat seperti teks atau judul biasa
FrancescoMM
4

Saya rasa saya menemukan solusi yang kompatibel dengan FF31 !!!
Berikut adalah dua opsi yang dijelaskan dengan baik di tautan ini:
http://www.currelis.com/hiding-select-arrow-firefox-30.html

Saya menggunakan opsi 1: Rodrigo-Ludgero memposting perbaikan ini di Github, termasuk online demo. Saya menguji demo ini di Firefox 31.0 dan tampaknya berfungsi dengan benar. Diuji pada Chrome dan IE juga. Berikut ini adalah kode 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>

dan 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

Ini bekerja sangat baik untuk saya!

ferocesalatino
sumber
2
Tautan ke sumber daya eksternal dianjurkan, tetapi tolong tambahkan konteks di sekitar tautan sehingga sesama pengguna Anda akan mengetahui apa itu dan mengapa ada di sana. Selalu kutip bagian yang paling relevan dari tautan penting, jika situs target tidak dapat dijangkau atau offline secara permanen.
Andrew Stubbs
Terima kasih atas sarannya! Maaf atas kesalahan saya!
ferocesalatino
Terima kasih telah mengedit pertanyaan Anda, namun tetap tidak menjawab pertanyaan itu dengan sendirinya . Silakan salin bagian-bagian dari tautan itu yang akan membantu si penanya sehingga mereka dapat menyelesaikan masalah mereka dengan membaca Jawaban Anda.
Andrew Stubbs
2

Sayangnya untuk Anda ini adalah "sesuatu yang mewah". Biasanya ini bukan tempat penulis web untuk mendesain ulang elemen formulir. Banyak browser yang sengaja tidak membiarkan Anda menata mereka, agar pengguna dapat melihat kontrol OS yang biasa mereka gunakan.

Satu-satunya cara untuk melakukan ini secara konsisten melalui browser dan sistem operasi, adalah menggunakan JavaScript dan mengganti selectelemen dengan yang "DHTML".

Artikel berikut menunjukkan tiga plugin berbasis jQuery yang memungkinkan Anda melakukan itu (ini agak lama, tapi saya tidak dapat menemukan apa pun saat ini)

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

RoToRa
sumber
8
Saya tidak setuju bahwa ini adalah sesuatu yang mewah, meskipun itu adalah sesuatu yang eksperimental. Seluruh poin dari appearanceproperti adalah untuk memberikan pengembang kontrol atas tampilan elemen bentuk, karena menggunakan JavaScript untuk itu adalah solusi yang mengerikan. Peramban seharusnya tidak membuat keputusan tentang bagaimana sesuatu terlihat di halaman - ini adalah keputusan UX, bukan keputusan vendor browser. Sayangnya, itu belum didukung dengan baik. Mungkin satu tahun lagi.
RussellUresti
Saya tidak menganggap "mewah" jika saya ingin itu ketika Anda mencetak halaman semua pilihan terlihat seperti bidang tanpa panah. Dan itu harus menjadi pilihan saya, bukan pilihan browser atau os. Saya memiliki pilih dengan bulan, dan ketika halaman dicetak saya memiliki CSS khusus untuk cetak yang menghilangkan panah pada halaman yang dicetak sehingga terlihat seperti judul "Maret" tanpa panah yang tidak masuk akal pada halaman yang dikutip.
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; 
    }
}
Todd Bruss
sumber
+20 untuk menyarankan menggunakan elemen semu
Zach Saucier
2

Saya styling yang dipilih hanya suka ini

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

Ini berfungsi untuk saya di FF, Safari, dan Chrome di semua versi yang telah saya uji.

Dalam IE saya masukkan:

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

Anda juga dapat: .yourclass :: - ms-expand {display: none; } .Anda :: - ms-exapan {display: none; }

Alex Moleiro
sumber
1

Saya tahu pertanyaan ini agak lama, tetapi karena muncul di google, dan ini adalah solusi "baru":

appearance: normalTampaknya berfungsi baik di Firefox untuk saya (versi 5 sekarang). tetapi tidak di Opera dan IE8 / 9

Sebagai solusi untuk Opera dan IE9, saya menggunakan :before pseudoselector untuk membuat kotak putih baru dan meletakkannya di atas panah.

Sayangnya, di IE8 ini tidak berhasil. Kotak ini diberikan dengan benar, tetapi panah tetap saja mencuat ...: - /

Menggunakan select:beforeberfungsi dengan baik di Opera, tetapi tidak di IE. Jika saya melihat alat pengembang, saya melihatnya membaca aturan dengan benar, dan kemudian mengabaikannya (mereka dicoret). Jadi saya menggunakan <span class="selectwrap">yang sebenarnya <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;
}

Anda mungkin perlu mengubah ini sedikit, tetapi ini bekerja untuk saya!

Penafian: Saya menggunakan ini untuk mendapatkan salinan halaman web dengan bentuk yang bagus sehingga saya tidak perlu membuat halaman kedua. Saya bukan 1337 haxx0r yang menginginkan scrollbar merah, <marquee>tag, dan yang lainnya :-) Harap jangan menerapkan style berlebihan pada formulir kecuali Anda memiliki alasan yang sangat bagus.

Martin Tournoij
sumber
3
-moz-appearance: normaltampaknya tidak menjadi opsi yang valid di Fx 9, dan -moz-appearance: none(yang valid) tidak menghapus panah bawah.
Robin Winslow
Solusi rentang tumpang tindih Anda berfungsi di IE dan FF tetapi tidak berfungsi di Chrome.
gagak vulcan
: before dan: after pseudo-elements hanya bekerja pada elemen yang menerima konten dalam. Itu bukan kasus pilih, atau input, atau fileuploader, dll. Mereka bagus untuk divs, tautan, paragraf, dll. Alasannya adalah bahwa mereka menambahkan konten bukan sebelum / setelah THE ELEMENT itu sendiri tetapi sebelum IT'S KANDUNGAN. Dan elemen pilih tidak mendukung sesuatu seperti <select> hi.
João Cunha
1

Gunakan pointer-eventsproperti.

Idenya di sini adalah untuk overlay elemen di atas panah drop down asli (untuk membuat custom kami) dan kemudian melarang event pointer di atasnya. [lihat posting ini ]

Berikut ini adalah FIDDLE yang berfungsi menggunakan metode ini.

Juga, dalam jawaban SO ini saya membahas ini dan metode lain secara lebih rinci.

Danield
sumber
1

Ini berfungsi (diuji pada Firefox 23.0.1):

select {
    -moz-appearance: radio-container;
}
Ixx
sumber
Bekerja untuk saya, tapi saya tidak suka radio-containernilai untuk objek yang dipilih. Jelajahi referensi mozilla -moz-penampilan untuk mendapatkan nilai yang sesuai (saya menggunakan menulist-textyang menyembunyikan panah pilihan di FF 31)
sglessard
1

membangun jawaban oleh @ JoãoCunha, satu gaya css yang berguna untuk lebih dari satu browser

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

Lebih jauh ke jawaban Joao Cunha , masalah ini sekarang ada di Daftar ToDo Mozilla dan ditargetkan untuk ver 35.

Bagi yang menginginkan, berikut adalah solusi dari Todd Parker, dirujuk di blog Cunha, yang berfungsi hari ini:

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;
}
crashwap
sumber
1

Sejak Firefox 35, " -moz-appearance:none" yang sudah Anda tulis dalam kode Anda, akhirnya hapus tombol panah yang diinginkan.

Itu adalah bug yang dipecahkan sejak versi itu.

Luca Detomi
sumber
1

Banyak Diskusi Terjadi di sana-sini tetapi saya tidak melihat beberapa solusi yang tepat untuk masalah ini. Akhirnya diakhiri dengan menulis kode Jquery + CSS kecil untuk melakukan HACK ini di IE & Firefox.

Hitung Lebar Elemen (Elemen PILIH) menggunakan Jquery. Tambahkan Wrapper Around Element Pilih dan Keep overflow disembunyikan untuk elemen ini. Pastikan Lebar bungkus ini tepat. 25px kurang dari Elemen SELECT. Ini bisa dengan mudah dilakukan dengan Jquery. Jadi Sekarang Ikon Kita Telah Hilang ..! dan sekarang saatnya untuk menambahkan ikon gambar kita pada elemen SELECT ... !!! Cukup tambahkan beberapa baris sederhana untuk menambahkan latar belakang dan Anda semua Selesai .. !! Pastikan untuk menggunakan overflow tersembunyi untuk pembungkus luar,

Berikut adalah Contoh Kode yang dilakukan untuk Drupal. Namun dapat digunakan untuk orang lain juga dengan menghapus beberapa baris kode yang spesifik 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;
}

Solusi berfungsi di Semua Peramban IE, Chrome & Firefox Tidak perlu Menambah Hacks Fixed Widths Menggunakan CSS. Semuanya ditangani secara dinamis menggunakan JQuery.!

Lebih Dijelaskan di: - http://northwebstudio.com/blogs/1/jquery/remove-drop-down-arrow-html-select-element-using-jquery-and-css

pengguna3058338
sumber
1

coba css ini

select {
    /*for firefox*/
    -moz-appearance: none;
    /*for chrome*/
    -webkit-appearance:none;
}

Bekerja

subindas pm
sumber
0

The appearanceproperti dari CSS3 tidak memungkinkan nonenilai. Lihatlah referensi W3C . Jadi, apa yang Anda coba lakukan tidak valid (memang Chrome seharusnya tidak menerima juga).

Maka sayangnya kami benar-benar tidak memiliki solusi lintas browser untuk menyembunyikan panah itu menggunakan CSS murni. Seperti yang ditunjukkan, Anda perlu JavaScript.

Saya sarankan Anda untuk mempertimbangkan menggunakan plugin selectBox jQuery . Ini sangat ringan dan dilakukan dengan baik.

Erick Petrucelli
sumber
1
Tetapi noneADALAH nilai yang diklaim Firefox untuk didukung: developer.mozilla.org/en/CSS/-moz-appearance Sementara elemen bentuk penataan, di masa lalu, hanya dapat dicapai melalui JavaScript, seluruh titik appearanceproperti adalah untuk menjauh dari itu. Vendor browser tidak boleh membuat keputusan UX untuk pengembang. Sayangnya, sepertinya ini masih sedikit terlalu baru untuk digunakan secara efektif.
RussellUresti
1
@RussellUresti, oleh karena itu meskipun deskripsi dari awalan vendor -mozmenerima none(bahkan jika itu berhasil) tidak akan benar untuk menggunakannya. Bahkan lebih banyak tentang browser seperti Firefox, yang selalu membanggakan dirinya dengan persis mengikuti standar.
Erick Petrucelli
0

Anda bisa menambah lebar kotak dan memindahkan panah lebih dekat ke kiri panah. ini kemudian memungkinkan Anda untuk menutupi panah dengan div putih kosong.

Lihat: http://jsbin.com/aniyu4/86/edit

user909410
sumber
0

Apakah Anda menerima perubahan kecil pada html?

Sesuatu seperti meletakkan tag div yang berisi tag pilih.

Lihatlah.

Galled
sumber
0

Atau, Anda dapat klip pilih. Sesuatu di sepanjang garis:

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

Ini harus klip 30px dari sisi kanan kotak pilih, menghilangkan panah. Sekarang menyediakan gambar latar belakang 170px dan voila, gaya pilih

Dusan Smolnikar
sumber
0

Ini adalah retasan besar, tetapi -moz-appearance: menulist-textmungkin bisa melakukan trik.

Segera
sumber
Tampaknya memang menghapus panah pilih untuk saya, tetapi sebagai @dendini mencatat, itu juga menghapus semua styling pada elemen
codestr
0

Saya mengalami masalah yang sama. Sangat mudah untuk membuatnya bekerja pada FF dan Chrome, tetapi pada IE (8+ yang perlu kami dukung) semuanya menjadi rumit. Solusi termudah yang dapat saya temukan untuk elemen pilih khusus yang berfungsi "di mana pun saya mencoba", termasuk IE8, menggunakan .customSelect ()

rafaelbiten
sumber
0

Peretasan yang bermanfaat bagi saya adalah untuk mengatur tampilan (memilih) inline-flex. Memotong panah keluar dari tombol pilih saya. Tanpa semua kode yang ditambahkan.

  • Hanya untuk Fx. -webkit appearancemasih dibutuhkan untuk Chrome, dll ...
Andrew Ice
sumber
2
Tampaknya tidak berpengaruh
Chris Nicola
0

Jawaban Jordan Young adalah yang terbaik. Tetapi jika Anda tidak dapat atau tidak ingin mengubah HTML Anda, Anda dapat mempertimbangkan untuk menghapus panah bawah kustom yang disajikan untuk Chrome, Safari, dll dan meninggalkan panah default firefox - tetapi tanpa menghasilkan panah ganda. Tidak ideal, tetapi perbaikan cepat yang baik yang tidak menambahkan HTML apa pun dan tidak mengganggu tampilan khusus Anda di peramban lain.

<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;
  }
}
squarecandy
sumber
0

hackity hack ... solusi yang berfungsi di setiap browser yang saya uji (Safari, Firefox, Chrome). Tidak memiliki IE yang ada, jadi alangkah baiknya jika Anda dapat menguji dan berkomentar:

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

CSS, dengan gambar yang disandikan 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

Saya menggunakan: after-element untuk menutupi panah jelek. Karena pilih tidak mendukung: setelah, saya perlu pembungkus untuk bekerja dengannya. Sekarang, jika Anda mengklik panah, dropdown tidak akan mendaftarkannya ... kecuali browser Anda mendukung pointer-events: none, yang semua orang kecuali IE10- tidak: http://caniuse.com/#feat=pointer-events

Jadi bagi saya itu sempurna - solusi yang bagus, bersih, tidak sakit kepala, setidaknya dibandingkan dengan semua opsi lain yang termasuk javascript.

tl; dr:

Jika IE10 (atau lebih rendah) Pengguna mengklik panah, itu tidak akan berfungsi. Bekerja cukup baik untukku ...

Sebastian Schmid
sumber
0

Jika Anda tidak keberatan mengutak-atik JS, saya menulis sebuah plugin jQuery kecil yang membantu Anda melakukannya. Dengan itu Anda tidak perlu khawatir tentang awalan vendor.

 $.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;
};

Fiddle di sini: JS Fiddle

Syaratnya adalah Anda harus mengatur pemilihan dari awal (ini berarti mengatur latar belakang dan batas), tetapi Anda mungkin tetap ingin melakukan ini.

Juga karena fungsi menggantikan pemilihan asli dengan div, Anda akan kehilangan gaya yang dilakukan secara langsung pada pemilih pilih di CSS Anda. Jadi berikan elemen pilih kelas dan gaya kelas.

Mendukung sebagian besar browser modern, jika Anda ingin menargetkan browser yang lebih lama, Anda dapat mencoba versi jQuery yang lebih lama, tetapi mungkin harus mengganti on () dengan bind () pada fungsi (tidak diuji)

Hydde87
sumber
-2

Jawaban lain sepertinya tidak berhasil untuk saya, tetapi saya menemukan retasan ini. Ini bekerja untuk saya (Juli 2014)

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

Dalam kasus saya, saya juga memiliki bidang input woocommerce jadi saya menggunakan ini

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

Diperbarui jawaban saya untuk menunjukkan pilih daripada input

Sol
sumber
input.input-teks? apa hubungannya dengan opsi pilih dan pertanyaan yang diajukan?
dendini