html - 如何使用引导列/网格系统将按钮放在输入框旁边?
问题描述
鉴于我正在使用引导列/网格系统,我如何能够在输入框旁边放置一个按钮?Label
is of 2, EditorFor
div of 4 and the input
div of 6. 如果我将 div 降低到EditorFor
3,它会使input/button
div 更靠近,但它会缩小EditorFor
该样式style = "border: 1px solid red;"
仅用于调试。
<div class="form-horizontal">
<div class="form-group">
@Html.LabelFor(model => model.Tag.Name, htmlAttributes: new { @class = "control-label col-md-2", style = "border: 1px solid red;" })
<div class="col-md-4" style = "border: 1px solid red;">
@Html.EditorFor(model => model.Tag.Name, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Tag.Name, "", new { @class = "text-danger" })
</div>
<div class="col-md-6" style = "border: 1px solid red;">
<input type="submit" value="Add Tag" class="btn btn-default" style = "border: 1px solid red;"/>
</div>
</div>
</div>
谢谢
- 额外的细节
这是html输出:
<div class="form-horizontal">
<div class="form-group">
<label class="control-label col-md-2" for="Tag_Name" style="border: 1px solid red;">Tag Name:</label>
<div class="col-md-4" style = "border: 1px solid red;">
<input class="form-control text-box single-line" data-val="true" data-val-length="Tag cannot be longer than 50 characters." data-val-length-max="50" data-val-regex="Must start with a capital letter, only alphabetic characters and no spaces allowed." data-val-regex-pattern="^[A-Z]+[a-zA-Z"'\s-]*$" data-val-required="The Tag Name: field is required." id="Tag_Name" name="Tag.Name" type="text" value="" />
<span class="field-validation-valid text-danger" data-valmsg-for="Tag.Name" data-valmsg-replace="true"></span>
</div>
<div class="col-md-6" style = "border: 1px solid red;">
<input type="submit" value="Add Tag" class="btn btn-default" style = "border: 1px solid red;"/>
</div>
</div>
</div>
解决方案
问题是@Html.EditorFor
有一个最大宽度。这意味着它永远不会达到col-md-4
或以上的宽度。所以我要么需要增加@Html.EditorFor
填充的最大宽度col-md-4
,要么使用col-md-3
使按钮更靠近输入。
由于引导程序的列/网格系统填充,使用col-md-3
会产生宽度EditorFor
缩小(相对于进程)的问题。EditorFor
在这种情况下,删除padding-right
/ 将其设置为0
删除此间隙,使其EditorFor
现在填充 col 的右侧。
最终代码:
<div class="form-group">
@Html.LabelFor(model => model.Tag.Name, htmlAttributes: new { @class = "control-label col-md-2", style = "border: 1px solid red;" })
<div class="col-md-3" style="border: 1px solid red; padding-right:0;">
@Html.EditorFor(model => model.Tag.Name, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Tag.Name, "", new { @class = "text-danger" })
</div>
<div class="col-md-7" style="border: 1px solid red;">
<input type="submit" value="Add Tag" class="btn btn-default" style="border: 1px solid red;" />
</div>
</div>
推荐阅读
- java - 如何关闭 Jackson2HttpMessageConverter
- scala - 如何使用akka-http设计一个rest api以便于测试?
- javascript - 在sequelize中按长度排序数组
- android - Creating an android custom view instead of multiple views with different data
- r - R - 将 POSIXct 格式化为列表中的日期
- multithreading - 使用 python 跟踪调试
- windows - 这是匹配文件名的 for 命令中的错误吗?
- python - 如何将 pandas PeriodIndex 转换为特定的财政年度字符串格式?
- microsoft-graph-api - 修补来自共享收件箱的邮件不起作用
- android - 检查是否下载了android OCR