使用Boostrap制作格式正确的响应表单

时间:2018-11-14 01:04:17

标签: html css asp.net-mvc twitter-bootstrap

总体来说,我在CSS领域还算陌生,所以请原谅。我正在尝试使用ASP.Net MVC(使用Razor)制作一个如下所示的表单:

enter image description here

这种旧形式是过去用大量表格,tr,td,p和br标签制成的,宽度固定,因此最终结果与预期的完全一样,但仅适用于一定尺寸的屏幕。除了屏幕大于1024x768之外,其他任何最终结果都是非常糟糕的,因为用户必须在垂直和水平方向上进行大量滚动操作。

我想做的就是将这种视觉效果复制到大屏幕上,但是以响应方式进行,这意味着它将在平板电脑或手机上以不同的方式排列。我在MVC 5和引导CSS中使用ASP.net。但是,我在复制布局时遇到麻烦(标签位于顶部,控件位于其下方)。

所以我的问题是这样的:用它做一个粗糙的html(带有bootstrap css)。总体上,有人可以推荐一个有关引导程序和CSS的好的教程吗?我知道很多,但实际上哪一个是商品?

谢谢

2 个答案:

答案 0 :(得分:2)

引导类是必经之路。该文档确实足够好。它很容易拿起,而且写起来非常容易。您在Bootstrap 4类中的示例:

<link href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.1.3/css/bootstrap.css" rel="stylesheet"/>

<div class="d-flex flex-column">
	<div class="w-50 d-flex flex-column pb-1">
		<label class="font-italic" for="reference">Reference</label>
		<span class="text-black-50">Votre numero de contrat ou le nom de famille</span>
		<input class="" id="reference" type="text" />
	</div>
	<div class="w-50 d-flex flex-column pb-1">
		<label class="font-italic" for="enterprise">Enterprise *</label>
		<input class="" id="enterprise" type="text" />
	</div>
	<div class="d-flex flex-row pb-1">
		<div class="w-50 d-flex flex-column">
			<label class="font-italic" for="address1">Adresse *</label>
			<input class="" id="address1" type="text" />
		</div>
		<div class="w-50 w-50 d-flex flex-column">
			<label class="font-italic" for="address2">Adresse</label>
			<input class="" id="address2" type="text" />
		</div>
	</div>
</div>

此后包含的类可能会占以后代码的一半以上。我充分利用了d-flex类,将其转换为弹性框。 pb-1代表填充底部,1 rem,w-50表示宽度50%。唯一的陷阱是flex-row将子元素划分为单独的列,而flex-column将其划分为行。

享受使用Bootstrap的乐趣,真的很棒。

答案 1 :(得分:2)

或者(也可以)在Bootstrap中,您可以使用grid system,它基于rowcol-*类。检查下一个示例:

<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous">
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js" integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy" crossorigin="anonymous"></script>

<div class="container-fluid">

  <div class="row">
    <div class="col-6">
      <label class="font-italic" for="reference">
        Référence
        <br>
        <small class="text-muted">Votre número de contrat ou le nom de famille</small>
      </label>          
      <input class="form-control" id="reference" type="text"/>
    </div>
  </div>
  
  <div class="row">  
    <div class="col-6">
      <label class="font-italic" for="enterprise">Enterprise *</label>
      <input class="form-control" id="enterprise" type="text"/>
    </div>
  </div>

  <div class="row">        
    <div class="col-6">
      <label class="font-italic" for="address1">Adresse *</label>
      <input class="form-control" id="address1" type="text" />
    </div>        
    <div class="col-6">
      <label class="font-italic" for="address2">Adresse</label>
      <input class="form-control" id="address2" type="text" />
    </div>
  </div>

</div>