html - 如何使用 form-inline bootstrap 3?

标签 html css forms twitter-bootstrap razor

我有一个 HTML 和 Razor View ,我正在尝试构建一个如下所示的表单: mockup image

但是,我能做到的最好的是:

result image

如您所见,标签未内联。 为了实现这一点,我已经阅读了 Bootstrap 3 ( http://getbootstrap.com/components/#navbar-forms ) 中的 form-inline 类,但是无论我如何使用 form-inline 我都无法在不进行整个布局的情况下将标签放到正确的位置一团糟。

这是我当前的代码(没有内联表单):

 <fieldset class="group-border">
                    <legend class="group-border">Info</legend>

                    <div class="row">
                        <div class="col-lg-4">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.NumDoc, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.NumDoc, new { @class = "form-control input-sm", placeholder = "Nº Documento", disabled = "disabled" })
                            </div>
                        </div>
                        <div class="col-lg-4">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.ProcessNum, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.ProcessNum, new { @class = "form-control input-sm", placeholder = "Nº Processo", disabled = "disabled" })
                            </div>
                        </div>
                        <div class="col-lg-4">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.State, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.State, new { @class = "form-control input-sm", placeholder = "Estado", disabled = "disabled" })
                            </div>
                        </div>
                    </div>

                    <div class="row">
                        <div class="col-lg-6">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.Name, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.Name, new { @class = "form-control input-sm", placeholder = "Nome Documento", disabled = "disabled" })
                            </div>
                        </div>
                        <div class="col-lg-6">
                            @Html.LabelFor(doc => doc.IsArchived, new { @class = "control-label" })
                            @Html.CheckBoxFor(doc => doc.IsArchived, new { @class = "input-sm", disabled = "disabled" })
                        </div>
                    </div>

                    <div class="row">
                        <div class="col-lg-6">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.Description, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.Description, new { @class = "form-control input-sm", placeholder = "Descrição", disabled = "disabled" })
                            </div>
                        </div>
                        <div class="col-lg-6">
                            <div class="form-group">
                                @Html.LabelFor(doc => doc.Date, new { @class = "control-label" })
                                @Html.TextBoxFor(doc => doc.Date, new { @class = "form-control input-sm", placeholder = "dd/MM/yyyy", disabled = "disabled" })
                            </div>
                        </div>
                    </div>

                </fieldset>

Bellow 是 HTML CSS 和 Javascript 中的代码片段,试图复制我所拥有的。

<style> legend.group-border {
  width: inherit;
  /* Or auto */
  padding: 0 10px;
  /* To give a bit of padding on the left and right */
  border-bottom: none;
}
fieldset.group-border {
  border: 1px groove #ddd !important;
  padding: 0 1.4em 1.4em 1.4em !important;
  margin: 0 0 1.5em 0 !important;
  -webkit-box-shadow: 0px 0px 0px 0px #000;
  box-shadow: 0px 0px 0px 0px #000;
}
</style>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet" />
<fieldset class="group-border">
  <legend class="group-border">Info</legend>

  <div class="row">
    <div class="col-lg-4">
      <div class="form-group">
        <label class="control-label" for="NumDoc">Nº Documento</label>
        <input class="form-control input-sm" data-val="true" data-val-number="The field Nº Documento must be a number." data-val-required="O campo Nº Documento é necessário." disabled="disabled" id="NumDoc" name="NumDoc" placeholder="Nº Documento" type="text"
        value="21354">
      </div>
    </div>
    <div class="col-lg-4">
      <div class="form-group">
        <label class="control-label" for="ProcessNum">Nº Processo</label>
        <input class="form-control input-sm" data-val="true" data-val-number="The field Nº Processo  must be a number." data-val-required="O campo Nº Processo  é necessário." disabled="disabled" id="ProcessNum" name="ProcessNum" placeholder="Nº Processo" type="text"
        value="54463">
      </div>
    </div>
    <div class="col-lg-4">
      <div class="form-group">
        <label class="control-label" for="State">Estado</label>
        <input class="form-control input-sm" disabled="disabled" id="State" name="State" placeholder="Estado" type="text" value="Em Inbox">
      </div>
    </div>
  </div>

  <div class="row">
    <div class="col-lg-6">
      <div class="form-group">
        <label class="control-label" for="Name">Nome</label>
        <input class="form-control input-sm" disabled="disabled" id="Name" name="Name" placeholder="Nome Documento" type="text" value="A134-MULTAS">
      </div>
    </div>
    <div class="col-lg-6">
      <label class="control-label" for="IsArchived">Arquivado?</label>
      <input checked="checked" class="input-sm" data-val="true" data-val-required="O campo Arquivado? é necessário." disabled="disabled" id="IsArchived" name="IsArchived" type="checkbox" value="true">
      <input name="IsArchived" type="hidden" value="false">
    </div>
  </div>

  <div class="row">
    <div class="col-lg-6">
      <div class="form-group">
        <label class="control-label" for="Description">Descrição</label>
        <input class="form-control input-sm" disabled="disabled" id="Description" name="Description" placeholder="Descrição" type="text" value="Fast and Furious">
      </div>
    </div>
    <div class="col-lg-6">
      <div class="form-group">
        <label class="control-label" for="Date">Data Documento</label>
        <input class="form-control input-sm" data-val="true" data-val-date="The field Data Documento must be a date." data-val-required="O campo Data Documento é necessário." disabled="disabled" id="Date" name="Date" placeholder="dd/MM/yyyy" type="text" value="25/08/2015 15:03:26">
      </div>
    </div>
  </div>

</fieldset>

如您所见,我有一行,分为 3 列(每列占用 4 个单位的宽度),里面有我使用 Razor 的表单。

如何修改我当前的 HTML 代码以实现模型中的结果?

最佳答案

这是代码片段,我只是将 form-group 类更改为 form-inline,更改了列数及其宽度,只是为了它可以添加 containerrowcol-md-12 div,我还尝试垂直对齐 checkbox 看起来更像您的第一个模型图像

<style> legend.group-border {
  width: inherit;
  /* Or auto */
  padding: 0 10px;
  /* To give a bit of padding on the left and right */
  border-bottom: none;
}
fieldset.group-border {
  border: 1px groove #ddd !important;
  padding: 0 1.4em 1.4em 1.4em !important;
  margin: 0 0 1.5em 0 !important;
  -webkit-box-shadow: 0px 0px 0px 0px #000;
  box-shadow: 0px 0px 0px 0px #000;
}
</style>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet" />
<div class="container">
            <div class="row">
                <div class="col-md-12">
                    <fieldset class="group-border">
                        <legend class="group-border">Info</legend>

                        <div class="row">
                            <div class="col-lg-4">
                                <div class="form-inline">
                                    <label class="control-label" for="NumDoc">Nº Documento</label>
                                    <input class="form-control input-sm" data-val="true" data-val-number="The field Nº Documento must be a number." data-val-required="O campo Nº Documento é necessário." disabled="disabled" id="NumDoc" name="NumDoc" placeholder="Nº Documento" value="21354" type="text">
                                </div>
                            </div>
                            <div class="col-lg-4">
                                <div class="form-inline">
                                    <label class="control-label" for="ProcessNum">Nº Processo</label>
                                    <input class="form-control input-sm" data-val="true" data-val-number="The field Nº Processo  must be a number." data-val-required="O campo Nº Processo  é necessário." disabled="disabled" id="ProcessNum" name="ProcessNum" placeholder="Nº Processo" value="54463" type="text">
                                </div>
                            </div>
                            <div class="col-lg-4">
                                <div class="form-inline">
                                    <label class="control-label" for="State">Estado</label>
                                    <input class="form-control input-sm" disabled="disabled" id="State" name="State" placeholder="Estado" value="Em Inbox" type="text">
                                </div>
                            </div>
                        </div>
                        <br>
                        <div class="row">
                            <div class="col-lg-1">
                                <label class="control-label" for="Name">Nome</label>
                            </div>
                            <div class="col-lg-7">
                                <input class="form-control input-sm" disabled="disabled" id="Name" name="Name" placeholder="Nome Documento" value="A134-MULTAS" type="text">
                            </div>
                            <div style="float: left;" class="col-lg-4 text-left">
                                <input style="float: left;" checked="checked" class="input-sm" data-val="true" data-val-required="O campo Arquivado? é necessário." disabled="disabled" id="IsArchived" name="IsArchived" value="true" type="checkbox">
                                <label style="margin-top: 10px; margin-left: 9px;" class="control-label" for="IsArchived">Arquivado?</label>
                                <input name="IsArchived" value="false" type="hidden">
                            </div>
                        </div>
                        <br>
                        <div class="row">
                            <div class="col-lg-1">
                                <label class="control-label" for="Description">Descrição</label>
                            </div>
                            <div class="col-lg-7">
                                <input class="form-control input-sm" disabled="disabled" id="Description" name="Description" placeholder="Descrição" value="Fast and Furious" type="text">
                            </div>
                            <div class="col-lg-4">
                                <div class="form-inline">
                                    <label class="control-label" for="Date">Data Documento</label>
                                    <input class="form-control input-sm" data-val="true" data-val-date="The field Data Documento must be a date." data-val-required="O campo Data Documento é necessário." disabled="disabled" id="Date" name="Date" placeholder="dd/MM/yyyy" value="25/08/2015 15:03:26" type="text">
                                </div>
                            </div>
                        </div>
                    </fieldset>
                </div>
            </div>
        </div>

关于html - 如何使用 form-inline bootstrap 3?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32206607/

相关文章:

html - 为什么有时页面内的 css 不能正常工作,就像这种情况?

html - 在已实现 FormData 和 XmlHttpRequest 的现代浏览器中是否存在缓冲区(大小或文件数量)限制?

JavaScript ID 选择器

javascript - 使用 JavaScript 更改 html 图像的每个刻度

javascript - 当用户单击按钮时显示 div 元素的错误

html - 无法使标题居中

两个元素之间的 CSS 覆盖不同?

javascript - CSS:性能方面,最好使用 calc 或 position absolute

其他提交的 PHP MySQL 日志

python - 如何从链接中获取完整的 url