如何使字体真棒图标出现在div的中心

时间:2018-04-25 10:56:22

标签: html css font-awesome

我用Google搜索了上述问题,但我仍然需要堆栈溢出社区的帮助。

在我的登录表单中,我使用的是字体真棒图标。我有2个输入框分别用于用户名和密码。 我想在用户名输入的顶部显示fa-user-cirle图标。登录表单显示在div中,如下所示:

<div class="loginDiv">
    <form>
        <i class="fa fa-user-circle"></i>

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

            <input type="password" placeholder="Password" name="psw" required>

            <button mat-button (click)="submit()">Login</button>

            <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: 215px;
    height: 36px;
    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;
    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;
    transform: scale(4,4);
    border-radius: 50%;
    }

我得到的输出如下:

enter image description here

但我希望图标显示在用户名输入的正上方和中心位置。 请帮帮我。

3 个答案:

答案 0 :(得分:0)

尝试在容器上方添加行

<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>

    <button mat-button (click)="submit()">Login</button>
    <label>
      <input type="checkbox" checked="checked" name="remember"> Remember me
    </label>

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

答案 1 :(得分:0)

感谢您给我提示,并在css中找到了以下更改的解决方案,

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

答案 2 :(得分:0)

添加此&#39; centericon&#39; Class和css

.centericon{
  font-size:36px;
  position:absolute;
  top:-18px;
  left:50%;
  transform:translate(-50%,0);
  z-index:99;
  background:white;
}

&#13;
&#13;
.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: 215px;
    height: 36px;
    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;
    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;
}
.centericon{
  font-size:36px;
  position:absolute;
  top:-18px;
  left:50%;
  transform:translate(-50%,0);
  z-index:99;
  background:white;
}
&#13;
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css"/>
<div class="loginDiv">
  <form>
    <div class="centericon">
    <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>

    <button mat-button (click)="submit()">Login</button>
    <label>
      <input type="checkbox" checked="checked" name="remember"> Remember me
    </label>

    </div>
  </form>
</div>
&#13;
&#13;
&#13;