[javascript] 선택 옵션에서 체크 박스를 사용하는 방법
클라이언트는 목록의 개별 항목으로 항목 이름과 함께 확인란이 포함 된 옵션 선택 메뉴가있는 디자인을 제공했습니다. 어쨌든 옵션 선택 메뉴 안에 확인란을 추가 할 수 있습니까?
주의 : 개발자는 메뉴를 효과적으로 만들기 위해 자신의 ID를 추가해야합니다. 가능한 경우 HTML CSS 코드 만 필요합니다.
답변
선택 요소 내부에 체크 박스를 배치 할 수 없지만 HTML, CSS 및 JavaScript를 사용하여 동일한 기능을 얻을 수 있습니다. 다음은 가능한 작업 솔루션입니다. 설명은 다음과 같습니다.
암호:
var expanded = false;
function showCheckboxes() {
var checkboxes = document.getElementById("checkboxes");
if (!expanded) {
checkboxes.style.display = "block";
expanded = true;
} else {
checkboxes.style.display = "none";
expanded = false;
}
}
.multiselect {
width: 200px;
}
.selectBox {
position: relative;
}
.selectBox select {
width: 100%;
font-weight: bold;
}
.overSelect {
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
}
#checkboxes {
display: none;
border: 1px #dadada solid;
}
#checkboxes label {
display: block;
}
#checkboxes label:hover {
background-color: #1e90ff;
}
<form>
<div class="multiselect">
<div class="selectBox" onclick="showCheckboxes()">
<select>
<option>Select an option</option>
</select>
<div class="overSelect"></div>
</div>
<div id="checkboxes">
<label for="one">
<input type="checkbox" id="one" />First checkbox</label>
<label for="two">
<input type="checkbox" id="two" />Second checkbox</label>
<label for="three">
<input type="checkbox" id="three" />Third checkbox</label>
</div>
</div>
</form>
설명:
먼저 “옵션 선택”이라는 텍스트를 표시하는 선택 요소와 선택 요소 ( <div class="overSelect">
) 를 덮는 (겹치는) 빈 요소를 만듭니다. 사용자가 선택 요소를 클릭하는 것을 원하지 않습니다. 빈 옵션이 표시됩니다. 요소를 다른 요소와 겹치려면 상대적인 값이있는 CSS 위치 속성을 사용합니다. 순수한.
기능을 추가하기 위해 사용자가 선택 요소 ( <div class="selectBox" onclick="showCheckboxes()">
) 가 포함 된 div를 클릭 할 때 호출되는 JavaScript 함수를 지정합니다 .
또한 체크 박스가 포함 된 div를 만들고 CSS를 사용하여 스타일을 지정합니다. 위에서 언급 한 JavaScript 함수 <div id="checkboxes">
는 CSS 표시 속성의 값을 “없음”에서 “차단”으로 또는 그 반대로 변경합니다.
이 솔루션은 Internet Explorer 10, Firefox 34, Chrome 39 브라우저에서 테스트되었습니다. 브라우저에서 JavaScript를 활성화해야합니다.
추가 정보:
CSS 위치
http://www.w3schools.com/css/css_positioning.asp
CSS 표시 속성
http://www.w3schools.com/cssref/pr_class_display.asp
답변
지금까지 최고의 플러그인은 Bootstrap Multiselect입니다.
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>jQuery Multi Select Dropdown with Checkboxes</title>
<link rel="stylesheet" href="css/bootstrap-3.1.1.min.css" type="text/css" />
<link rel="stylesheet" href="css/bootstrap-multiselect.css" type="text/css" />
<script type="text/javascript" src="http://code.jquery.com/jquery-1.8.2.js"></script>
<script type="text/javascript" src="js/bootstrap-3.1.1.min.js"></script>
<script type="text/javascript" src="js/bootstrap-multiselect.js"></script>
</head>
<body>
<form id="form1">
<div style="padding:20px">
<select id="chkveg" multiple="multiple">
<option value="cheese">Cheese</option>
<option value="tomatoes">Tomatoes</option>
<option value="mozarella">Mozzarella</option>
<option value="mushrooms">Mushrooms</option>
<option value="pepperoni">Pepperoni</option>
<option value="onions">Onions</option>
</select>
<br /><br />
<input type="button" id="btnget" value="Get Selected Values" />
<script type="text/javascript">
$(function() {
$('#chkveg').multiselect({
includeSelectAllOption: true
});
$('#btnget').click(function(){
alert($('#chkveg').val());
});
});
</script>
</div>
</form>
</body>
</html>
여기 데모입니다
$(function() {
$('#chkveg').multiselect({
includeSelectAllOption: true
});
$('#btnget').click(function() {
alert($('#chkveg').val());
});
});
.multiselect-container>li>a>label {
padding: 4px 20px 3px 20px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://davidstutz.de/bootstrap-multiselect/dist/js/bootstrap-multiselect.js"></script>
<link href="https://davidstutz.de/bootstrap-multiselect/docs/css/bootstrap-3.3.2.min.css" rel="stylesheet"/>
<link href="https://davidstutz.de/bootstrap-multiselect/dist/css/bootstrap-multiselect.css" rel="stylesheet"/>
<script src="https://davidstutz.de/bootstrap-multiselect/docs/js/bootstrap-3.3.2.min.js"></script>
<form id="form1">
<div style="padding:20px">
<select id="chkveg" multiple="multiple">
<option value="cheese">Cheese</option>
<option value="tomatoes">Tomatoes</option>
<option value="mozarella">Mozzarella</option>
<option value="mushrooms">Mushrooms</option>
<option value="pepperoni">Pepperoni</option>
<option value="onions">Onions</option>
</select>
<br /><br />
<input type="button" id="btnget" value="Get Selected Values" />
</div>
</form>
답변
A의 순수한 CSS의 방법, 당신은 사용할 수 있습니다 :checked
과 함께 선택 ::before
조건 내용을 인라인 선택합니다.
요소에 클래스 select-checkbox
를 추가하고 select
다음 CSS를 포함 하기 만하면 됩니다.
.select-checkbox option::before {
content: "\2610";
width: 1.3em;
text-align: center;
display: inline-block;
}
.select-checkbox option:checked::before {
content: "\2611";
}
다음과 같이 일반 이전 유니 코드 문자 ( 이스케이프 된 16 진수 인코딩 사용 )를 사용할 수 있습니다.
또는 멋지게 꾸미고 싶다면 다음 FontAwesome 글리프를 사용할 수 있습니다.
- .fa 평방 – 오 –
\f096
- .fa 검사 평방 – 오 –
\f046
jsFiddle 및 Stack Snippets의 데모
참고 : 그러나 IE 호환성 문제에주의하십시오 .
답변
다중 선택 , 특히 다중 항목을 시도하십시오 . 수많은 예제와 함께 훨씬 깨끗하고 관리되는 솔루션으로 보입니다. 소스를 볼 수도 있습니다.
<div>
<div class="form-group row">
<label class="col-sm-2">
Basic Select
</label>
<div class="col-sm-10">
<select multiple="multiple">
<option value="1">1</option>
<option value="2">2</option>
</select>
</div>
</div>
<div class="form-group row">
<label class="col-sm-2">
Group Select
</label>
<div class="col-sm-10">
<select multiple="multiple">
<optgroup label="Group 1">
<option value="1">1</option>
<option value="2">2</option>
</optgroup>
<optgroup label="Group 2">
<option value="6">6</option>
<option value="7">7</option>
</optgroup>
<optgroup label="Group 3">
<option value="11">11</option>
<option value="12">12</option>
</optgroup>
</select>
</div>
</div>
</div>
<script>
$(function() {
$('select').multipleSelect({
multiple: true,
multipleWidth: 60
})
})
</script>
답변
나는 @vitfo 대답에서 시작했지만 확인란 입력 대신 <option>
안에 <select>
넣고 싶습니다. 그래서 이것을 만들기 위해 모든 대답을 모았습니다. 내 코드가 있습니다. 누군가를 도울 수 있기를 바랍니다.
$(".multiple_select").mousedown(function(e) {
if (e.target.tagName == "OPTION")
{
return; //don't close dropdown if i select option
}
$(this).toggleClass('multiple_select_active'); //close dropdown if click inside <select> box
});
$(".multiple_select").on('blur', function(e) {
$(this).removeClass('multiple_select_active'); //close dropdown if click outside <select>
});
$('.multiple_select option').mousedown(function(e) { //no ctrl to select multiple
e.preventDefault();
$(this).prop('selected', $(this).prop('selected') ? false : true); //set selected options on click
$(this).parent().change(); //trigger change event
});
$("#myFilter").on('change', function() {
var selected = $("#myFilter").val().toString(); //here I get all options and convert to string
var document_style = document.documentElement.style;
if(selected !== "")
document_style.setProperty('--text', "'Selected: "+selected+"'");
else
document_style.setProperty('--text', "'Select values'");
});
:root
{
--text: "Select values";
}
.multiple_select
{
height: 18px;
width: 90%;
overflow: hidden;
-webkit-appearance: menulist;
position: relative;
}
.multiple_select::before
{
content: var(--text);
display: block;
margin-left: 5px;
margin-bottom: 2px;
}
.multiple_select_active
{
overflow: visible !important;
}
.multiple_select option
{
display: none;
height: 18px;
background-color: white;
}
.multiple_select_active option
{
display: block;
}
.multiple_select option::before {
content: "\2610";
}
.multiple_select option:checked::before {
content: "\2611";
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<select id="myFilter" class="multiple_select" multiple>
<option>A</option>
<option>B</option>
<option>C</option>
<option>D</option>
<option>E</option>
</select>
답변
확인란을 숨기려면 바깥 쪽을 클릭하는 대체 Vanilla JS 버전 :
let expanded = false;
const multiSelect = document.querySelector('.multiselect');
multiSelect.addEventListener('click', function(e) {
const checkboxes = document.getElementById("checkboxes");
if (!expanded) {
checkboxes.style.display = "block";
expanded = true;
} else {
checkboxes.style.display = "none";
expanded = false;
}
e.stopPropagation();
}, true)
document.addEventListener('click', function(e){
if (expanded) {
checkboxes.style.display = "none";
expanded = false;
}
}, false)
stopPropagation ()과 함께 캡처 / 버블 링 단계 옵션을 활용하기 위해 onClick 대신 addEventListener를 사용하고 있습니다. 캡처 / 버블 링에 대한 자세한 내용은 https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener 에서 읽을 수 있습니다.
나머지 코드는 vitfo의 원래 답변과 일치하지만 html에서 onclick ()이 필요하지 않습니다. 두 사람이 jQuery가 아닌이 기능을 요청했습니다.
다음은 코드 펜 예제입니다. https://codepen.io/davidysoards/pen/QXYYYa?editors=1010
답변
이 목적으로 git에서이 라이브러리를 사용할 수 있습니다.
https://github.com/ehynds/jquery-ui-multiselect-widget
선택 상자를 시작하려면 이것을 사용하십시오.
$("#selectBoxId").multiselect().multiselectfilter();
그리고 json (ajax 또는 모든 방법에서)에 데이터가 준비되면 먼저 데이터를 구문 분석 한 다음 js 배열을 할당하십시오
var js_arr = $.parseJSON(/*data from ajax*/);
$("#selectBoxId").val(js_arr);
$("#selectBoxId").multiselect("refresh");