選択/選択解除するために押すことができるチェックボックス「ボタン」を作成しようとしています。私が直面している問題は、ラベルがアクティブなときに、適用したスタイルを完全に認識しないことです。ボタンが押されたように見えるようにしたいのですが、現在、css の上部の境界線が認識されていません。ボタンが押されているように見えますが、上部の境界線が機能していないため、上部の境界線が追加されていないかのようにボタンが下に移動します。これが Javascript で Mousedown と Mouseup を使用して実行できる場合は、お知らせください。
http://jsfiddle.net/jasonniebauer/sf3W8/
<div id="card_acceptance">
<p>
Select all that apply:
</p>
<input type="checkbox" id="mc_credit" value=""/>
<label for="mc_credit" name="mc_credit_button">
MC Credit
</label>
<input type="checkbox" id="visa_credit" value=""/>
<label for="visa_credit">
Visa Credit
</label>
<input type="checkbox" id="discover_credit" value=""/>
<label for="discover_credit">
Discover Credit
</label>
<input type="checkbox" id="amex_id" value=""/>
<label for="amex_id">
AMEX
</label>
<input type="checkbox" id="pin_debit" value=""/>
<label for="pin_debit">
PIN-Based Debit
</label>
</div>
#card_acceptance p {
font-size: 1.125em;
margin-bottom: .5rem;
}
#card_acceptance input[type="checkbox"] + label,
#card_acceptance2 input[type="checkbox"] + label {
box-sizing:border-box;
padding: 1rem 3rem 1rem 3rem;
width: 100%;
display: block;
color: #BDC3C7;
background-color: #F2F2F2;
text-align: center;
vertical-align: middle;
cursor: pointer;
border-bottom: 4px solid #BDC3C7;
border-radius: 3px;
margin-bottom: 1rem;
}
#card_acceptance input[type="checkbox"] + label:hover,
#card_acceptance2 input[type="checkbox"] + label:hover {
background: #E8E8E8;
color: #898989;
-webkit-transition: border .25s linear, color .25s linear, background-color .25s linear;
-webkit-transition-property: border, color, background-color;
-webkit-transition-duration: 0.25s, 0.25s, 0.25s;
-webkit-transition-timing-function: linear, linear, linear;
-webkit-transition-delay: initial, initial, initial;
transition: border .25s linear, color .25s linear, background-color .25s linear;
transition-property: border, color, background-color;
transition-duration: 0.25s, 0.25s, 0.25s;
transition-timing-function: linear, linear, linear;
transition-delay: initial, initial, initial;
}
#card_acceptance input[type="checkbox"] + label:active,
#card_acceptance2 input[type="checkbox"] + label:active {
border-bottom: 0px;
border-top: 4px #FFFFFF;
border-radius: 3px;
}
#card_acceptance input[type="checkbox"]:checked + label,
#card_acceptance2 input[type="checkbox"]:checked + label {
background-color: #3498DB;
color: #FFFFFF;
outline: 0;
border-bottom: 4px solid #217DBB;
}
#card_acceptance input[type="checkbox"]:checked + label:hover,
#card_acceptance2 input[type="checkbox"]:checked + label:hover {
background-color: #258CD1;
color: #FFFFFF;
-webkit-transition: border .25s linear, color .25s linear, background-color .25s linear;
-webkit-transition-property: border, color, background-color;
-webkit-transition-duration: 0.25s, 0.25s, 0.25s;
-webkit-transition-timing-function: linear, linear, linear;
-webkit-transition-delay: initial, initial, initial;
transition: border .25s linear, color .25s linear, background-color .25s linear;
transition-property: border, color, background-color;
transition-duration: 0.25s, 0.25s, 0.25s;
transition-timing-function: linear, linear, linear;
transition-delay: initial, initial, initial;
}
#card_acceptance input[type="text"],
#card_acceptance2 input[type="text"] {
margin-bottom: 1rem;
display: none;
}
#card_acceptance input[type="checkbox"] {
display: none;
}
}