网页布局在不同的屏幕上显示不同

时间:2018-04-25 14:37:11

标签: html css sass responsive-design

我设计了我的网页,

HTML code,

<div class="firstDiv"></div>
<div class="secondDiv"></div>
<div class="loginDiv">
  <form>
      <div class="row center">
          <i class="fa fa-user-circle"></i>
      </div>

    <div class="container">
    <input type="text" placeholder="Username" name="uname" required>

    <input type="password" placeholder="Password" name="psw" required>
      <br/>
      <br/>
    <button mat-button (click)="submit()">Login</button>
    <br/>
    <label>
      <input type="checkbox" checked="checked" name="remember"> Remember me
    </label>

    </div>
  </form>
</div>

CSS代码,

@import '~@angular/material/theming';
@include mat-core();

$yaana-app-primary: mat-palette($mat-orange, 800,400,200);

.firstDiv {
    height: 40%;
    width: 100%;
    top: 0;
    left: 0;
    right: 0;
    position: absolute;
    background-color: orangered;
    display: inline-block;
}

.secondDiv {
    position: absolute;
    width: 100%;
    bottom: 0;
    height: 60%;
    left: 0;
    right: 0;
    background-color:whitesmoke;
    display: inline-block;
}

.loginDiv {
    border: 1px solid black;
    background: white;
    left: 50%;
    position: absolute;
    top: 28%;
    transform: translate(-50%);
    background-color: #fff;
    padding: 15px;
    box-shadow:1px 3px 10px rgba(0, 0, 0, 0.34);
}
input[type=text], input[type=password] {
    width: 100%;
    padding: 12px 20px;
    margin: 8px 0;
    display: inline-block;
    border: 1px solid #ccc;
    box-sizing: border-box;
}
button {
    width: 60%;
    height: 20%;
    line-height: 36px;
    background: transparent;
    border-radius: 3px;
    will-change: transform;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
    border: none;
    /*border: 2px solid #FF5126;*/
    cursor: pointer;
    background: #F26722;
    font-size: 16px;
    color: #fff;
    outline: none;
    text-align: center;
    padding: 0 6px;
    margin: 6px 8px;
    display: block;
    margin: auto;
    font-size: 14px;
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.26);
    text-transform: uppercase !important;
}

button:hover {
    opacity: 0.8;
}
.loginImgContainer {
    display: table;
    max-height: 40px;
    max-width: 40px;
}

i.fa {
    background: #fff;
    display: inline-block;
    font-size: 80px;
    transform: translateY(-60%);
    transform: translateX(160%);
    border-radius: 50%;
    margin: auto;
    position: relative;
    }

当我运行网页时,我会得到不同的观点,

1)对于桌面浏览器

enter image description here

2)适用于iPhone 6等小屏幕

enter image description here

3)对于Ipad Pro,

enter image description here

我希望用户图标显示在中心,但它会根据屏幕尺寸偏离中心。

3 个答案:

答案 0 :(得分:0)

试试这个圆圈div

position: absolute;
left: 0;
right: 0;
margin: auto;

答案 1 :(得分:0)

将flexbox用于包含圆圈的行。来源中的文档。

/* Added display flex for circle row */

div.row.center {
  display: flex;
  justify-content: center;
  width: 100%;
}

.firstDiv {
  height: 40%;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  position: absolute;
  background-color: orangered;
  display: inline-block;
}

.secondDiv {
  position: absolute;
  width: 100%;
  bottom: 0;
  height: 60%;
  left: 0;
  right: 0;
  background-color: whitesmoke;
  display: inline-block;
}

.loginDiv {
  border: 1px solid black;
  background: white;
  left: 50%;
  position: absolute;
  top: 28%;
  transform: translate(-50%);
  background-color: #fff;
  padding: 15px;
  box-shadow: 1px 3px 10px rgba(0, 0, 0, 0.34);
}

input[type=text],
input[type=password] {
  width: 100%;
  padding: 12px 20px;
  margin: 8px 0;
  display: inline-block;
  border: 1px solid #ccc;
  box-sizing: border-box;
}

button {
  width: 60%;
  height: 20%;
  line-height: 36px;
  background: transparent;
  border-radius: 3px;
  will-change: transform;
  -webkit-transition: all .2s ease;
  transition: all .2s ease;
  border: none;
  /*border: 2px solid #FF5126;*/
  cursor: pointer;
  background: #F26722;
  font-size: 16px;
  color: #fff;
  outline: none;
  text-align: center;
  padding: 0 6px;
  margin: 6px 8px;
  display: block;
  margin: auto;
  font-size: 14px;
  box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.26);
  text-transform: uppercase !important;
}

button:hover {
  opacity: 0.8;
}

.loginImgContainer {
  display: table;
  max-height: 40px;
  max-width: 40px;
}

i.fa {
  background: #fff;
  display: inline-block;
  font-size: 80px;
  /* transform: translateY(-60%); removed */
  /* transform: translateX(160%); removed */
  border-radius: 50%;
  /* margin: auto; removed */
  /* position: relative; removed */
}
<link href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" />
<div class="firstDiv"></div>
<div class="secondDiv"></div>
<div class="loginDiv">
  <form>
    <div class="row center">
      <i class="fa fa-user-circle"></i>
    </div>
    <div class="container">
      <input type="text" placeholder="Username" name="uname" required>
      <input type="password" placeholder="Password" name="psw" required>
      <br/>
      <br/>
      <button mat-button (click)="submit()">Login</button>
      <br/>
      <label>
      <input type="checkbox" checked="checked" name="remember"> Remember me
    </label>
    </div>
  </form>
</div>

答案 2 :(得分:0)

超级易于修复。

由于某些原因,您已对圈子进行了转换,请参阅代码:

i.fa {
background: #fff;
display: inline-block;
font-size: 80px;
/* transform: translateY(-60%); */
/* transform: translateX(160%); */
border-radius: 50%;
margin: auto;
position: relative;
}

删除已注释掉的这两行,然后添加以下css:

.center {
    text-align: center;
}