[html] CSS를 사용하여 라디오 버튼의 크기를 변경하는 방법은 무엇입니까?

CSS에서 라디오 버튼의 크기를 제어하는 ​​방법이 있습니까?



답변

예, 모든 요소와 마찬가지로 높이와 너비를 설정할 수 있어야합니다. 그러나 일부 브라우저는 이러한 속성을 실제로 고려하지 않습니다.

이 데모는 가능한 사항과 다양한 브라우저에서 어떻게 표시되는지에 대한 개요를 제공합니다.
https://www.456bereastreet.com/lab/styling-form-controls-revisited/radio-button/

보시다시피 라디오 버튼 스타일링은 쉽지 않습니다. 😀

해결 방법은 JavaScript 및 CSS를 사용하여 라디오 버튼 및 기타 양식 요소를 사용자 정의 이미지로 바꾸는 것입니다.


답변

이 CSS는 트릭을 수행하는 것 같습니다.

input[type=radio] {
    border: 0px;
    width: 100%;
    height: 2em;
}

테두리를 0으로 설정하면 사용자가 버튼의 크기를 변경하고 브라우저가 예를 들어 해당 크기로 렌더링하도록 할 수 있습니다. 위의 높이 : 2em은 라인 높이의 두 배로 버튼을 렌더링합니다. 이것은 확인란 ( input[type=checkbox]) 에도 적용됩니다 . 일부 브라우저는 다른 브라우저보다 더 잘 렌더링됩니다.

Windows 상자에서 IE8 +, FF21 +, Chrome29 +에서 작동합니다.


답변

오래된 질문이지만 이제 대부분의 브라우저와 호환되는 간단한 솔루션이 있습니다 CSS3. IE, Firefox 및 Chrome에서 테스트했으며 작동합니다.

input[type="radio"] {
    -ms-transform: scale(1.5); /* IE 9 */
    -webkit-transform: scale(1.5); /* Chrome, Safari, Opera */
    transform: scale(1.5);
}

값을 변경합니다 1.5.이 경우 필요에 따라 크기가 50 % 씩 증가합니다. 비율이 매우 높으면 라디오 버튼이 흐려질 수 있습니다. 다음 이미지는 1.5의 비율을 보여줍니다.

여기에 이미지 설명 입력

여기에 이미지 설명 입력


답변

CSS 스타일로 라디오 버튼의 크기를 제어 할 수 있습니다.

style = “height : 35px; width : 35px;”

라디오 버튼 크기를 직접 제어합니다.

<input type="radio" name="radio" value="value" style="height:35px; width:35px; vertical-align: middle;">


답변

직접적으로는 아닙니다. 사실 일반적으로 양식 요소는 CSS만으로 스타일을 지정하는 데 문제가 있거나 불가능합니다. 가장 좋은 방법은 다음과 같습니다.

  1. 자바 스크립트를 사용하여 라디오 버튼을 숨 깁니다.
  2. 자바 스크립트를 사용하여 원하는 방식으로 스타일을 지정할 수있는 HTML을 추가 / 표시합니다.
  3. 선택한 상태에 대한 CSS 규칙을 정의합니다.이 규칙은 “selected”클래스를 yuor 범위에 추가하여 트리거됩니다.
  4. 마지막으로, 라디오 버튼의 상태가 스팬 클릭에 반응하도록 자바 스크립트를 작성하고, 그 반대로 라디오 버튼의 상태 변경에 스팬이 반응하도록합니다 (사용자가 키보드를 사용하여 양식에 액세스하는 경우). 두 번째 부분은 모든 브라우저에서 작동하기가 까다로울 수 있습니다. 다음과 같은 것을 사용합니다 (jQuery도 사용합니다. 스타일을 지정하고 “선택된”클래스를 입력 레이블에 직접 적용하여 추가 범위를 추가하는 것을 피합니다).

자바 스크립트

var labels = $("ul.radioButtons).delegate("input", "keyup", function () { //keyboard use
        if (this.checked) {
            select($(this).parent());
        }
    }).find("label").bind("click", function (event) { //mouse use
        select($(this));
    });

function select(el) {
    labels.removeClass("selected");
    el.addClass("selected");
}

HTML

<ul class="radioButtons">
    <li>
        <label for="employee1">
            employee1
            <input type="radio" id="employee1" name="employee" />
        </label>
    </li>
    <li>
        <label for="employee2">
            employee1
            <input type="radio" id="employee2" name="employee" />
        </label>
    </li>
</ul>


답변

기본 위젯 크기 조정이 모든 브라우저에서 작동하는 것은 아니지만 JavaScript로 사용자 정의 라디오 버튼을 만들 수 있습니다. 방법 중 하나는 숨겨진 라디오 버튼을 만든 다음 페이지에 자신의 이미지를 배치하는 것입니다. 이 이미지를 클릭하면 이미지가 변경되고 (클릭 한 이미지는 선택한 상태의 라디오 버튼으로 이미지로 교체되고 다른 이미지는 선택되지 않은 상태의 라디오 버튼으로 교체됩니다) 새 라디오 버튼을 선택합니다.

어쨌든이 주제에 대한 문서가 있습니다. 예를 들어, CSS 및 JavaScript를 사용하여 체크 박스 및 라디오 버튼 스타일 지정을 읽어보십시오 .


답변

여기에 한 가지 접근 방식이 있습니다. 기본적으로 라디오 버튼은 레이블의 약 두 배였습니다.
(답변 끝에 CSS 및 HTML 코드 참조)


Safari: 10.0.3

여기에 이미지 설명 입력


Chrome: 56.0.2924.87

여기에 이미지 설명 입력


Firefox: 50.1.0

여기에 이미지 설명 입력


Internet Explorer: 9 (IE의 잘못이 아닌 난처함, netrenderer.com에서 호스팅 된 테스트)

여기에 이미지 설명 입력


CSS :

.sortOptions > label {
    font-size:          8px;
}

.sortOptions > input[type=radio] {
    width:              10px;
    height:             10px;
}

HTML :

<div class="rightColumn">Answers
    <span class="sortOptions">
        <input type="radio" name="answerSortList" value="credate"/>
        <label for="credate">Creation</label>

        <input type="radio" name="answerSortList" value="lastact"/>
        <label for="lastact">Activity</label>

        <input type="radio" name="answerSortList" value="score"/>
        <label for="score">Score</label>

        <input type="radio" name="answerSortList" value="upvotes"/>
        <label for="upvotes">Up votes</label>

        <input type="radio" name="answerSortList" value="downvotes"/>
        <label for="downvotes">Down Votes</label>

        <input type="radio" name="answerSortList" value="accepted"/>
        <label for="downvotes">Accepted</label>

    </span>
</div>