CSS停止文本和输入并排

时间:2014-07-03 20:47:41

标签: javascript jquery html css

这是我正在使用的样式表:

/*custom font*/
    @import url(http://fonts.googleapis.com/css?family=Montserrat);

    /*basic reset*/
    * {margin: 0; padding: 0;}

    html {
        height: 100%;
        /*Image only BG fallback*/
        background: url('http://thecodeplayer.com/uploads/media/gs.png');
        /*background = gradient + image pattern combo*/
        background: 
            linear-gradient(rgba(196, 102, 0, 0.2), rgba(155, 89, 182, 0.2)), 
            url('http://thecodeplayer.com/uploads/media/gs.png');
    }

    body {
        font-family: montserrat, arial, verdana;
    }

    /*form styles*/
    #msform {
        width: 600px;
        margin: 50px auto;
        text-align: center;
        position: relative;
        font-family: montserrat;
        color: #2C3E50;
        font-size: 13px;
    }
    #msform fieldset {
        background: white;
        border: 0 none;
        border-radius: 3px;
        box-shadow: 0 0 15px 1px rgba(0, 0, 0, 0.4);
        padding: 20px 30px;

        box-sizing: border-box;
        width: 80%;
        margin: 0 10%;

        /*stacking fieldsets above each other*/
        position: absolute;
    }


    /*For the table*/
    #msform table {
        padding: 15px;
        border: 1px solid #ccc;
        border-radius: 3px;
        margin-bottom: 10px;
        width: 100%;
        box-sizing: border-box;
        font-family: montserrat;
        color: #2C3E50;
        font-size: 13px;
    }

    /*Hide all except first fieldset*/
    #msform fieldset:not(:first-of-type) {
        display: none;
    }
    /*inputs*/
    #msform input, #msform textarea {
        padding: 15px;
        border: 1px solid #ccc;
        border-radius: 3px;
        margin-bottom: 10px;
        width: 100%;
        box-sizing: border-box;
        font-family: montserrat;
        color: #2C3E50;
        font-size: 13px;
    }
    /*buttons*/
    #msform .action-button {
        width: 100px;
        background: #27AE60;
        font-weight: bold;
        color: white;
        border: 0 none;
        border-radius: 1px;
        cursor: pointer;
        padding: 10px 5px;
        margin: 10px 5px;
    }
    #msform .action-button:hover, #msform .action-button:focus {
        box-shadow: 0 0 0 2px white, 0 0 0 3px #27AE60;
    }
    /*headings*/
    .fs-title {
        font-size: 15px;
        text-transform: uppercase;
        color: #2C3E50;
        margin-bottom: 10px;
    }
    .fs-subtitle {
        font-weight: normal;
        font-size: 13px;
        color: #666;
        margin-bottom: 20px;
    }
    /*progressbar*/
    #progressbar {
        margin-bottom: 30px;
        overflow: hidden;
        /*CSS counters to number the steps*/
        counter-reset: step;
    }
    #progressbar li {
        list-style-type: none;
        color: white;
        text-transform: uppercase;
        font-size: 9px;
        width: 33.33%;
        float: left;
        position: relative;
    }
    #progressbar li:before {
        content: counter(step);
        counter-increment: step;
        width: 20px;
        line-height: 20px;
        display: block;
        font-size: 10px;
        color: #333;
        background: white;
        border-radius: 3px;
        margin: 0 auto 5px auto;
    }
    /*progressbar connectors*/
    #progressbar li:after {
        content: '';
        width: 100%;
        height: 2px;
        background: white;
        position: absolute;
        left: -50%;
        top: 9px;
        z-index: -1; /*put it behind the numbers*/
    }
    #progressbar li:first-child:after {
        /*connector not needed before the first step*/
        content: none; 
    }
    /*marking active/completed steps green*/
    /*The number of the step and the connector before it = green*/
    #progressbar li.active:before,  #progressbar li.active:after{
        background: #27AE60;
        color: white;
    }

当我尝试使用列表/表并使用以下格式的内容时,文本和输入类型(单选/复选框)将转到下一行而不是并排对齐。我该如何改变

<ul>

    <li>Facebook <input type="checkbox" name="SocialAccount" value="Facebook"></li>
    <li>Twitter <input type="checkbox" name="SocialAccount" value="Facebook"></li>
    <li>Instagram <input type="checkbox" name="SocialAccount" value="Facebook"></li>
    <li>Tumblr <input type="checkbox" name="SocialAccount" value="Facebook"></li>
    <li>Pinterest <input type="checkbox" name="SocialAccount" value="Facebook"></li>
    <li>Flickr <input type="checkbox" name="SocialAccount" value="Facebook"></li>
    <li>Others, Please specify. <input type="checkbox" name="SocialAccount" value="Facebook"></li>
</ul>

附上它的外观截图。任何帮助将不胜感激。

enter image description here

2 个答案:

答案 0 :(得分:2)

如果您希望checkbox与您网页上的文字位于同一行:

width:100%;

移除#msform input, #msform textarea

DEMO

答案 1 :(得分:2)

将上述评论扩展为答案:

这将导致复选框换行到下一行,因为它会使复选框与父容器一样宽:

input {width:100%}
<li>Facebook <input type="checkbox" name="SocialAccount" value="Facebook"></li>

如果你想将宽度:100%应用于文本输入字段和textareas,你几乎总是想要覆盖复选框和单选按钮:

input[type="checkbox"], input[type="radio"] {width:auto}

http://jsfiddle.net/DdH92/