잘 작동하는 텍스트 입력에 자리 표시자를 사용하고 있습니다. 그러나 선택 상자에도 자리 표시자를 사용하고 싶습니다. 물론 나는이 코드를 사용할 수 있습니다 :
<select>
<option value="">Select your option</option>
<option value="hurr">Durr</option>
</select>
그러나 ‘옵션 선택’은 밝은 회색 대신 검은 색입니다. 따라서 내 솔루션은 CSS 기반 일 수 있습니다. jQuery도 괜찮습니다.
이것은 드롭 다운에서 옵션을 회색으로 만듭니다 (화살표를 클릭 한 후).
option:first {
color: #999;
}
문제는 사람들이 어떻게 선택 상자에서 자리 표시자를 만드는가?입니다. 그러나 이미 답변을 받았습니다.
그리고 이것을 사용하면 선택한 값이 항상 회색으로 표시됩니다 (실제 옵션을 선택한 후에도).
select {
color: #999;
}
답변
CSS가 아닌 JavaScript / jQuery 답변이 없습니다.
<select>
<option value="" disabled selected>Select your option</option>
<option value="hurr">Durr</option>
</select>
답변
방금이 질문을 우연히 발견했으며 다음은 Firefox 및 Chrome에서 작동하는 것입니다.
<style>
select:invalid { color: gray; }
</style>
<form>
<select required>
<option value="" disabled selected hidden>Please Choose...</option>
<option value="0">Open when powered (most valves do this)</option>
<option value="1">Closed when powered, auto-opens when power is cut</option>
</select>
</form>
장애인 옵션은 중지 <option>
바로 사용이 반면, 마우스와 키보드 모두 선택의 존재를 'display:none'
여전히 키보드 화살표를 통해 사용자가 선택할 수 있습니다. 이 'display:none'
스타일은 목록 상자를 ‘좋은’모양으로 만듭니다.
참고 : value
“자리 표시 자”옵션에서 빈 속성을 사용 하면 유효성 검사 (필수 속성)가 “자리 표시 자”를 가지고 문제를 해결할 수 있으므로 옵션이 변경되지 않았지만 필요한 경우 브라우저는 옵션을 선택하라는 메시지를 표시해야합니다. 목록에서.
업데이트 (2015 년 7 월) :
이 방법은 다음 브라우저에서 작동하는 것으로 확인되었습니다.
- 구글 크롬-v.43.0.2357.132
- Mozilla Firefox-v.39.0
- Safari-v.8.0.7 (자리 표시자가 드롭 다운에 표시되지만 선택할 수는 없음)
- Microsoft Internet Explorer-v.11 (자리 표시자가 드롭 다운에 표시되지만 선택할 수는 없음)
- Project Spartan-v.15.10130 (자리 표시자가 드롭 다운에 표시되지만 선택할 수는 없음)
업데이트 (2015 년 10 월) :
나는 제거 된 style="display: none"
HTML5 속성에 찬성 hidden
폭 넓은 지원을하고있다. hidden
요소는 유사한 특성이 display: none
(가) 사파리, 인터넷 익스플로러, (프로젝트 스파르타가 검사를 필요로)의 option
드롭 다운 메뉴에서 볼 수 있습니다,하지만 그것은 선택할 수 없습니다.
업데이트 (2016 년 1 월) :
때 select
요소가 required
그것의 사용을 허용 :invalid
당신이 스타일을 할 수 있습니다 CSS 의사 클래스 select
때의 “자리”상태에서 요소를. :invalid
자리 표시 자의 빈 값으로 인해 여기에서 작동합니다 option
.
값이 설정되면 :invalid
의사 클래스가 삭제됩니다. :valid
원하는 경우 선택적으로 사용할 수도 있습니다 .
대부분의 브라우저는이 유사 클래스를 지원합니다. Internet Explorer 10 이상 이것은 사용자 정의 스타일 select
요소 와 가장 잘 작동 합니다. 경우에 따라 (예 : Chrome / Safari의 Mac) select
특정 스타일이 표시되도록 상자 의 기본 모양을 변경해야합니다 ( 예 : background-color
및) color
. developer.mozilla.org 에서 호환성에 대한 몇 가지 예와 자세한 내용을 찾을 수 있습니다. .
Chrome의 기본 요소 모양 Mac :
Chrome에서 변경된 경계 요소 Mac 사용 :
답변
필수 필드의 경우 최신 브라우저에 순수한 CSS 솔루션이 있습니다.
select:required:invalid {
color: gray;
}
option[value=""][disabled] {
display: none;
}
option {
color: black;
}
<select required>
<option value="" disabled selected>Select something...</option>
<option value="1">One</option>
<option value="2">Two</option>
</select>
답변
이 같은:
HTML :
<select id="choice">
<option value="0" selected="selected">Choose...</option>
<option value="1">Something</option>
<option value="2">Something else</option>
<option value="3">Another choice</option>
</select>
CSS :
#choice option { color: black; }
.empty { color: gray; }
자바 스크립트 :
$("#choice").change(function () {
if($(this).val() == "0") $(this).addClass("empty");
else $(this).removeClass("empty")
});
$("#choice").change();
실제 예 : http://jsfiddle.net/Zmf6t/
답변
방금 option
아래와 같이 숨겨진 속성을 추가했습니다 . 그것은 나를 위해 잘 작동합니다.
<select>
<option hidden>Sex</option>
<option>Male</option>
<option>Female</option>
</select>
답변
아래 솔루션은 JavaScript없이 Firefox에서도 작동합니다.
option[default] {
display: none;
}
<select>
<option value="" default selected>Select Your Age</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
</select>
답변
나는 똑같은 문제가 있었고 검색하는 동안이 질문을 발견했으며 좋은 해결책을 찾은 후에 누군가에게 도움이 될 수 있도록 여러분과 공유하고 싶습니다.
여기있어:
HTML :
<select class="place_holder dropdown">
<option selected="selected" style=" display: none;">Sort by</option>
<option>two</option>
<option>something</option>
<option>4</option>
<option>5</option>
</select>
CSS :
.place_holder {
color: gray;
}
option {
color: #000000;
}
자바 스크립트 :
jQuery(".dropdown").change(function () {
jQuery(this).removeClass("place_holder");
});
고객이 첫 번째 선택을 한 후에는 회색이 필요하지 않으므로 JavaScript 코드가 클래스를 제거합니다 place_holder
.
@ user1096901 덕분에 Internet Explorer 브라우저의 해결 방법으로 place_holder
첫 번째 옵션을 다시 선택한 경우 클래스를 다시 추가 할 수 있습니다.