วิธีลบลูกศรออกจากองค์ประกอบที่เลือกใน 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ไม่กำจัดรายการแบบหล่นลง

ความคิดใด ๆ ไม่จาวาสคริปต์ไม่ใช่ตัวเลือก


3
มีรายงานข้อผิดพลาดเกี่ยวกับเรื่องนี้ในขณะนี้: bugzilla.mozilla.org/show_bug.cgi?id=649849
sneilan

3
Chosenเป็นไลบรารี่ JavaScript ที่มีสไตล์ที่คุณเลือกและทำให้มันดูแฟนซี อาจเป็นสิ่งที่ควรพิจารณาแม้ว่าอาจจะไม่สามารถแก้ปัญหาของคุณได้
stephenmurdoch

คุณอาจพบว่าการโพสต์บล็อกนี้มีประโยชน์: red-team-design.com/making-html-dropdowns-not-suck
Rui Marques

1
ดูเหมือนว่าพวกเขาได้เพิ่ม-moz-appearanceคุณสมบัติ CSS3 แล้วฉันกำลังใช้งานอยู่-moz-appearance: none;และดูเหมือนจะใช้งานได้ในเวอร์ชัน 35.0.1
Tony M

การแก้ไขอย่างง่ายจะทำให้องค์ประกอบที่เลือกกว้างกว่าคอนเทนเนอร์ และห่อคำนำหน้า URL ของโมซิลล่าเพื่อให้ตัวเลือกนั้นกว้างขึ้นใน Firefox เท่านั้น @-moz-document url-prefix() { select { width: 105%; overflow: hidden; } }
ลุค Femur

คำตอบ:


78

โอเคฉันรู้ว่าคำถามนี้มีอายุ แต่ 2 ปีตามรอยและโมซิลล่าไม่ได้ทำอะไรเลย

ฉันคิดวิธีแก้ปัญหาง่ายๆ

การทำเช่นนี้จะเป็นการตัดการจัดรูปแบบทั้งหมดของกล่องที่เลือกใน Firefox และล้อมรอบองค์ประกอบรอบ ๆ กล่องที่เลือกด้วยสไตล์ที่คุณกำหนดเอง แต่ควรใช้กับ 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 ให้เพิ่มองค์ประกอบการขยายรอบ ๆ ด้วยคลาส '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 เพื่อซ่อนลูกศรสกปรกของโมซิลล่าด้วย -moz-Appearance: window และโยนลูกศรที่กำหนดเองลงในคลาส 'css-select-moz' ของคลาส Span แต่ให้แสดงบนโมซิลล่าแบบนี้เท่านั้น:

.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เพื่อให้ผู้อื่นดูและอัปเดต CSS เพียงเล็กน้อยเท่านั้น การขยายกว้างกว่าตัวเลือกใน FF เนื่องจากการเติมด้านขวาหมายความว่าการคลิกที่ลูกศรไม่ได้เปิดใช้งานการเลื่อนลง หากต้องการปรับสำหรับสิ่งนี้ฉันได้วางระยะขอบขวาติดลบบนองค์ประกอบที่เลือกเพื่อดึงความกว้างของช่วงกลับเข้าไปเพื่อซ้อนทับความกว้างของตัวเลือก
RussellUresti

โอ้แน่นอน! ขอบคุณมากรัสเซล ดีใจจริง ๆ ที่ช่วยได้
Jordan Young

5
ไม่ได้ผลสำหรับฉันใน FF 23-24 ใน Windows (ฉันลอง jsbin ในความคิดเห็น) ลงเอยด้วยการใช้วิธีแก้ปัญหาstackoverflow.com/questions/6787667/ นี้ในวันนี้
เอสเตบัน

4
มันไม่ทำงานบน FF 30 อีกต่อไป โปรดไปข้างหน้าและส่งตั๋วในเว็บไซต์ของ Mozilla: bugzilla.mozilla.org/show_bug.cgi?id=649849 ยิ่งมีคนบ่นเกี่ยวกับเรื่องนี้มากเท่าไหร่โอกาสที่เราจะแก้ไขก็มีมากขึ้นเท่านั้น
สแตน

1
ใช้งานได้กับ FF 31 บน Mac เท่านั้น
Erwin Wessels

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 ลบออก จะอัปเดตงานเขียนของฉันตามนั้นขอบคุณสำหรับสิ่งนั้น
João Cunha

ฉันเพิ่ม crossbrowser นิดหน่อย (ยังไม่ได้ทดสอบใน IE เวอร์ชั่นเก่า) เป็นคำตอบเพื่อให้คุณสามารถอัปเดตของคุณได้
Daniël Tulp

2
ทางออกที่ดีที่สุดสำหรับฉันเนื่องจาก-moz-appearence: windowไม่ได้ทำงานกับพื้นหลังโปร่งใส (วาด bg น่าเกลียดในสถานที่อย่างน้อยใน firefox linux)
kik

เนื่องจากเป็นการลบลูกศรทั้งหมด <select> ที่ได้ผลลัพธ์จึงดูเหมือนกล่องข้อความและมันค่อนข้างน่าเกลียด ดังนั้นคุณสามารถเพิ่มภาพพื้นหลังกลับมาเพื่อให้ดูเหมือนเป็นแบบเลื่อนลง: codepen.io/anon/pen/nvfCq
thom_nic

59

เคล็ดลับที่เหมาะกับฉันคือการเลือกความกว้างมากกว่า 100% และใช้การล้น: ซ่อน

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

นี่เป็นวิธีเดียวที่จะซ่อนลูกศรดรอปดาวน์ใน FF ได้แล้ว

BTW ถ้าคุณต้องการให้ดรอปดาวน์ที่สวยงามใช้http://harvesthq.github.com/chosen/


6
สิ่งนี้ไม่มีผลสำหรับฉัน FF 6.0.2
Charlie Schliesser

1
ทางออกที่ดีสำหรับ IE เช่นกัน ในโซลูชันของฉันฉันตั้งองค์ประกอบ div ที่มีเกิน: ซ่อนแล้วทำให้ความกว้างของการเลือกที่ใหญ่กว่า ใช้งานได้ดี
Mike

@Charlie S: พยายามใส่ overflow: ซ่อนอยู่ใน div ที่มี มันใช้ได้กับฉันด้วย taht
PierrOz

1
เมื่อคุณขยายเมนูแบบเลื่อนลงการโอเวอร์
Marc

ทำงานได้ดีสำหรับฉัน มันทำให้รายการแบบเลื่อนลงกว้างกว่าบิตบนเล็กน้อยเล็กน้อย แต่นั่นคือราคาที่ฉันยินดีจ่าย
Jimbali

26

การอัปเดตที่สำคัญ:

ในฐานะของ Firefox V35 ตอนนี้คุณสมบัติของรูปลักษณ์ใช้งานได้แล้ว !!

จากบันทึกประจำรุ่นอย่างเป็นทางการของ firefox ใน V35 :

การใช้-moz-appearanceกับnoneค่าบนคอมโบบ็อกซ์ตอนนี้ลบปุ่มแบบเลื่อนลง (ข้อผิดพลาด 649849)

ดังนั้นเพื่อซ่อนลูกศรเริ่มต้น - มันง่ายพอ ๆ กับการเพิ่มกฎต่อไปนี้ในองค์ประกอบที่เราเลือก:

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

การสาธิต

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

เราพบวิธีที่ง่ายและเหมาะสมในการทำเช่นนี้ มันข้ามเบราว์เซอร์ย่อยสลายได้และไม่ทำลายโพสต์แบบฟอร์ม ชุดแรกกล่องเลือกเป็นไปopacity0

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

อัปเดต InnerHTML ของ div ด้วย javascript Easypeasy กับ jQuery:

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

แค่นั้นแหละ! เพียงแค่สไตล์ div ของคุณแทนการเลือกกล่อง ฉันยังไม่ได้ทดสอบโค้ดข้างต้นดังนั้นคุณอาจต้องปรับแต่งมัน แต่หวังว่าคุณจะได้รับส่วนสำคัญ

{-webkit-appearance: none;}ผมคิดว่านี่เต้นแก้ปัญหา สิ่งที่เบราว์เซอร์ควรทำมากที่สุดคือการกำหนดปฏิสัมพันธ์กับองค์ประกอบของฟอร์ม แต่ไม่แน่นอนว่าการแสดงครั้งแรกบนหน้าเว็บเป็นอย่างไรเมื่อแบ่งการออกแบบเว็บไซต์


6
มันไม่ได้เป็นทางออกที่ดีและคล้ายกับรูปแบบที่ฉันเคยเห็นเพื่อจัดแต่งองค์ประกอบการป้อนข้อมูลการอัปโหลดไฟล์ แต่มีข้อเสียหลายประการ ก่อนอื่นอาศัย JS ซึ่งไม่เหมาะ ประการที่สองถ้าแบบฟอร์มมีปุ่มรีเซ็ตคุณต้องสคริปต์การทำงานนั้นด้วย (ตอนนี้ JS จะฟังเฉพาะการคลิกสำหรับองค์ประกอบที่เลือก แต่ไม่ตอบสนองต่อเหตุการณ์ form.reset) การแทนที่องค์ประกอบที่เลือกด้วย 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) แต่องค์ประกอบที่สามารถแสดงผลที่มองไม่เห็นด้วยสี: โปร่งใส ไม่สมบูรณ์ แต่เป็นการเริ่มต้นและคุณไม่จำเป็นต้องแทนที่องค์ประกอบระดับระบบด้วย js หนึ่ง


ใช่ฉันสังเกตเห็นว่าwindowมีผลกระทบนั้นน่าเสียดายที่ฉันต้องตั้งค่าภาพพื้นหลัง โชคไม่ดีที่ Firefox ไม่ดีเท่านี้
RussellUresti

เป็นเรื่องน่าเสียดายที่คุณไม่สามารถใช้การรีเซ็ตแบบเต็มเพื่อสร้างองค์ประกอบใช่ คุณสามารถปลอมพื้นหลังได้เสมอโดยมีองค์ประกอบอยู่ใต้ <select> ซึ่งไม่เหมาะแน่นอน
Stuart Badminton

1
นี่คือที่สมบูรณ์แบบสำหรับการพิมพ์! เพียงตั้งค่าmedia="print"บล็อก css ด้วยselect {-moz-appearance: window;}และจะลบลูกศรและพื้นหลังของตัวเลือกทั้งหมดใน FF (สำหรับเบราว์เซอร์อื่น ๆ ลองใช้ลักษณะที่ปรากฏหรือ -webkit-ลักษณะ) เพื่อให้พวกเขาดูเหมือนข้อความธรรมดาหรือชื่อ
FrancescoMM

4

ฉันคิดว่าฉันพบวิธีแก้ปัญหาที่เข้ากันได้กับ FF31 !!!
นี่คือสองตัวเลือกที่อธิบายได้ดีที่ลิงค์นี้:
http://www.currelis.com/hiding-select-arrow-firefox-30.html

ฉันใช้ตัวเลือกที่ 1: Rodrigo-Ludgero โพสต์การแก้ไขนี้ใน 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
ลิงก์ไปยังแหล่งข้อมูลภายนอกได้รับการสนับสนุน แต่โปรดเพิ่มบริบทรอบ ๆ ลิงก์เพื่อให้ผู้ใช้ของคุณมีความคิดว่ามันคืออะไรและเพราะเหตุใด อ้างถึงส่วนที่เกี่ยวข้องที่สุดของลิงค์สำคัญเสมอในกรณีที่เว็บไซต์เป้าหมายไม่สามารถเข้าถึงหรือออฟไลน์อย่างถาวร
Andrew Stubbs

ขอบคุณสำหรับคำแนะนำ! ขออภัยสำหรับความผิดพลาดของฉัน!
ferocesalatino

ขอขอบคุณสำหรับการแก้ไขคำถามของคุณ แต่มันยังไม่จริงตอบคำถามด้วยตัวเอง โปรดคัดลอกส่วนต่างๆของลิงก์เหล่านั้นที่จะช่วยผู้ถามในการแก้ปัญหาของพวกเขาเพียงแค่อ่านคำตอบของคุณ
Andrew Stubbs

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 พิเศษสำหรับการพิมพ์ที่ลบลูกศรบนหน้าที่พิมพ์ดังนั้นจึงดูเหมือนชื่อเรื่อง "มีนาคม" โดยไม่มีลูกศรที่ไม่สมเหตุสมผลบนหน้าที่ถูก prited
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 สำหรับการแนะนำโดยใช้องค์ประกอบปลอม
Zach Saucier

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 ตอนนี้) แต่ไม่ใช่ใน Opera และ IE8 / 9

เป็นวิธีแก้ปัญหาสำหรับ Opera และ IE9 ฉันใช้ :before pseudoselector เพื่อสร้างกล่องสีขาวใหม่และวางลูกศรไว้ด้านบน

น่าเสียดายที่ใน 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(ซึ่งใช้ได้) ไม่ได้ลบลูกศรลง
Robin Winslow

วิธีแก้ไขปัญหาการทับซ้อนของคุณทำงานใน IE และ FF แต่ไม่สามารถใช้งานได้ใน Chrome
Raven vulcan

: ก่อนและ: หลังจากองค์ประกอบแบบหลอกทำงานเฉพาะกับองค์ประกอบที่ยอมรับเนื้อหาภายในเท่านั้น นั่นไม่ใช่กรณีของการเลือกหรือการป้อนข้อมูลหรือ fileuploader ฯลฯ พวกเขาดีสำหรับ divs, ลิงค์, ย่อหน้า ฯลฯ เหตุผลที่ว่าพวกเขาผนวกเนื้อหาไม่ก่อน / หลังตัวเอง แต่ก่อนที่มัน เนื้อหา. <select> hiและองค์ประกอบเลือกไม่สนับสนุนสิ่งที่ต้องการ
João Cunha

1

ใช้pointer-eventsคุณสมบัติ

แนวคิดที่นี่คือการซ้อนทับองค์ประกอบบนลูกศรดรอปดาวน์แบบดั้งเดิม (เพื่อสร้างองค์ประกอบที่กำหนดเองของเรา) จากนั้นไม่อนุญาตเหตุการณ์ตัวชี้บน [ดูโพสต์นี้ ]

นี่คือFIDDLE ที่ทำงานโดยใช้วิธีนี้

นอกจากนี้ในคำตอบดังนั้นฉันพูดถึงเรื่องนี้และวิธีอื่นในรายละเอียดมากขึ้น


1

ใช้งานได้ (ทดสอบกับ Firefox 23.0.1):

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

ใช้งานได้สำหรับฉัน แต่ฉันไม่ชอบradio-containerค่าสำหรับวัตถุที่เลือก เรียกดู-moz- ลักษณะ mozilla อ้างอิงเพื่อรับค่าที่เหมาะสม (ฉันใช้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แล้วปัญหานี้อยู่ในรายชื่อ ToDo List ของ Mozillaและมีเป้าหมายสำหรับ ver 35

สำหรับผู้ปรารถนานี่คือวิธีแก้ปัญหาโดย Todd Parker อ้างอิงในบล็อกของ Cunha ที่ทำงานวันนี้:

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

คำนวณความกว้างขององค์ประกอบ (องค์ประกอบที่เลือก) โดยใช้ Jquery เพิ่ม Wrapper Around เลือกอิลิเมนต์และซ่อนโอเวอร์โฟลว์สำหรับอิลิเมนต์นี้ ตรวจสอบให้แน่ใจว่าความกว้างของ wrapper นี้เป็น appox น้อยกว่า 25px ขององค์ประกอบที่เลือก สิ่งนี้สามารถทำได้ง่ายด้วย Jquery ดังนั้นตอนนี้ไอคอนของเราคือหายไป .. ! และถึงเวลาสำหรับการเพิ่มไอคอนรูปภาพของเราในองค์ประกอบที่เลือก ... !!! เพียงเพิ่มสองสามบรรทัดง่ายๆสำหรับเพิ่มพื้นหลังและคุณก็เรียบร้อย .. !! ตรวจสอบให้แน่ใจว่าใช้ล้นที่ซ่อนอยู่สำหรับเสื้อคลุมด้านนอก

นี่คือตัวอย่างของรหัสที่ทำสำหรับ Drupal อย่างไรก็ตามสามารถใช้กับผู้อื่นได้ด้วยการลบโค้ดไม่กี่บรรทัดซึ่งเป็น Drupal Specific

/*
 * 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 ไม่จำเป็นต้องเพิ่ม Hacks ความกว้างคงที่โดยใช้ CSS มันถูกจัดการแบบไดนามิกโดยใช้ JQuery.!

อธิบายเพิ่มเติมได้ที่: - http://northwebstudio.com/blogs/1/jquery/remove-drop-down-arrow-html-select-element-using-jquery-and-csscs-



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 ซึ่งมักจะอวดตัวเองโดยปฏิบัติตามมาตรฐาน
Erick Petrucelli

0

คุณสามารถเพิ่มความกว้างของกล่องและย้ายลูกศรเข้าใกล้ด้านซ้ายของลูกศร สิ่งนี้จะช่วยให้คุณครอบคลุมลูกศรด้วย div สีขาวที่ว่างเปล่า

ลองดู: http://jsbin.com/aniyu4/86/edit


0

คุณจะยอมรับการเปลี่ยนแปลงเล็กน้อยใน html หรือไม่

สิ่งที่ชอบใส่แท็ก div ที่มีแท็กเลือก

ลองดูสิ.


0

หรือคุณสามารถเลือกคลิป บางสิ่งบางอย่างตาม:

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

สิ่งนี้ควรคลิป 30px ของทางด้านขวาของกล่องที่เลือกและลอกลูกศรออก ตอนนี้ให้ภาพพื้นหลัง 170px และ voila เลือกสไตล์


0

มันเป็นแฮ็คขนาดใหญ่ แต่-moz-appearance: menulist-textอาจทำเคล็ดลับได้


สิ่งนี้ดูเหมือนว่าจะลบลูกศรที่เลือกสำหรับฉัน แต่ตามที่ @dendini ระบุไว้มันก็นำสไตล์อื่น ๆ ออกไปในองค์ประกอบด้วย
codestr

0

ฉันมีปัญหาเดียวกัน ง่ายที่จะทำให้ใช้งานได้บน FF และ Chrome แต่ใน IE (8+ ที่เราต้องการการสนับสนุน) สิ่งต่าง ๆ มีความซับซ้อน ทางออกที่ง่ายที่สุดที่ฉันสามารถหาองค์ประกอบการเลือกแบบกำหนดเองที่ใช้งานได้ "ทุกที่ที่ฉันพยายาม" รวมถึง IE8 กำลังใช้. customSelect ()


0

สับประโยชน์สำหรับฉันคือการตั้งค่าการแสดง (เลือก) inline-flexเพื่อ ตัดลูกศรออกจากปุ่มเลือกของฉัน โดยไม่ต้องเพิ่มรหัสทั้งหมด

  • สำหรับ Fx เท่านั้น -webkit appearanceยังจำเป็นสำหรับ Chrome และอื่น ๆ ...

2
ดูเหมือนจะไม่มีผลใด ๆ
Chris Nicola

0

คำตอบของ Jordan Young นั้นดีที่สุด แต่ถ้าคุณไม่สามารถหรือไม่ต้องการเปลี่ยน 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 ไม่รองรับ: หลังจาก, ฉันต้องการ wrapper เพื่อใช้งาน ตอนนี้ถ้าคุณจะคลิกที่ลูกศรดรอปดาวน์จะไม่ลงทะเบียน ... เว้นแต่เบราว์เซอร์ของคุณรองรับpointer-events: noneซึ่งทุกคนยกเว้น IE10- จะ: http://caniuse.com/#feat=pointer-events

ดังนั้นสำหรับฉันมันสมบูรณ์แบบ - วิธีแก้ปัญหาที่ดีสะอาดและปวดหัวอย่างน้อยเมื่อเปรียบเทียบกับตัวเลือกอื่น ๆ ทั้งหมดซึ่งรวมถึงจาวาสคริปต์

TL; DR:

หากผู้ใช้ 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 รุ่นเก่ากว่าได้ แต่อาจต้องแทนที่ () ด้วย bind () ในฟังก์ชัน (ไม่ได้ทดสอบ)


-2

คำตอบอื่น ๆ ดูเหมือนจะไม่ทำงานสำหรับฉัน แต่ฉันพบแฮ็คนี้ สิ่งนี้ใช้ได้สำหรับฉัน (กรกฎาคม 2014)

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

ในกรณีของฉันฉันมีฟิลด์อินพุต woocommerce ดังนั้นฉันจึงใช้มัน

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

อัปเดตคำตอบของฉันเพื่อแสดงการเลือกมากกว่าการป้อนข้อมูล


input.input-text? ต้องทำอย่างไรกับตัวเลือกที่เลือกและคำถามที่ถาม
dendini
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.