总体来说,我在CSS领域还算陌生,所以请原谅。我正在尝试使用ASP.Net MVC(使用Razor)制作一个如下所示的表单:
这种旧形式是过去用大量表格,tr,td,p和br标签制成的,宽度固定,因此最终结果与预期的完全一样,但仅适用于一定尺寸的屏幕。除了屏幕大于1024x768之外,其他任何最终结果都是非常糟糕的,因为用户必须在垂直和水平方向上进行大量滚动操作。
我想做的就是将这种视觉效果复制到大屏幕上,但是以响应方式进行,这意味着它将在平板电脑或手机上以不同的方式排列。我在MVC 5和引导CSS中使用ASP.net。但是,我在复制布局时遇到麻烦(标签位于顶部,控件位于其下方)。
所以我的问题是这样的:用它做一个粗糙的html(带有bootstrap css)。总体上,有人可以推荐一个有关引导程序和CSS的好的教程吗?我知道很多,但实际上哪一个是商品?
谢谢
答案 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,它基于row
和col-*
类。检查下一个示例:
<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>