Font Awesome CSS Псевдоэлементы - PullRequest
0 голосов
/ 29 мая 2018

Я использую Font Awesome SVG с JavaScript несколько раз в проекте.Сейчас я пытаюсь создать кнопку, чтобы при наведении курсора на значок со стрелкой справа от текста, указывающего вправо.Когда кнопка наведена, появляется только пустой квадрат, где должен быть значок, и значок появляется слева с текстом.

Использование

display:none 

избавило от пустого значка справа от текста кнопки.

Как сделать так, чтобы значок отображался в пустом квадрате?

Это код

window.FontAwesomeConfig = {
        searchPseudoElements: true
}
.fa-arrow-right:before {
    font-family: 'Font Awesome 5 Solid';
    content: "\f061";
    font-weight: 900;

}


 .btn-4 {
    border-radius: 50px;
    border: 3px solid #fff;
    color: #fff;
    overflow: hidden;
}

.btn-4:active {
    border-color: #17954c;
    color: #17954c;
}

.btn-4:hover {
    background: #24b662;
}

.btn-4:before {
    position: absolute;
    height: 100%;
    font-size: 125%;
    line-height: 3.5;
    color: #fff;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
}

.btn-4:active:before {
    color: #17954c;
}

/* Button 4a */
.btn-4a:before {
    left: 130%;
    top: 0;
}

.btn-4a:hover:before {
    left: 80%;
}

/* Button 4b */
.btn-4b:before {
    left: -50%;
    top: 0;
}

.btn-4b:hover:before {
    left: 10%;
}
<script defer src="https://use.fontawesome.com/releases/v5.0.13/js/all.js" integrity="sha384-xymdQtn1n3lH2wcu0qhcdaOpQwyoarkgLVxC/wZ5q7h9gHtxICrpcaSUfygqZGOe" crossorigin="anonymous"></script>
<div class="container mw-100 mx-auto margin-top-70 purple-background">
        <div class="row">
         <div class="col-8" id="forum">
            <h2 class="text-center margin-top-40">Join the Book Club</h2>
            <p class="feature-text">What are you reading? Share the book love over on the forum</p>
         </div>
         <div class="col-4">
          <div class="margin-top-60">
            <button class="btn btn-4 btn-4a fa-arrow-right">Join Us</button>
          </div>
        </div>
      </div>
    </div>

Я сделал снимки экрана, чтобы проиллюстрировать проблему * Кнопки и при наведении

Ответы [ 2 ]

0 голосов
/ 29 мая 2018

Наряду с классом fa-arrow-right также добавьте класс fa.

Убедитесь, что вы удалили дополнительные правила, которые вы применили.

.fa-arrow-right:before {
    font-family: 'Font Awesome 5 Solid';
    content: "\f061";
    font-weight: 900;
}

faкласс сделает все это за вас.

Надеюсь, это поможет.

0 голосов
/ 29 мая 2018

Чтобы использовать font-awesome, вы должны определить семейство шрифтов, а в контент ввести внушительный список шрифтов.

Font-family:

font-family: FontAwesome;

Содержимое:

content: '/f2bb' // exemple

Шпаргалка - https://fontawesome.com/cheatsheet

h1 {
  margin: 25px auto;
  font-size: 40px;
  text-align: center;
  font-family: sans-serif;	
}

.box {
  width: 150px;
  height: 150px;
  background-color: #CD5C5C;
  margin: 0 auto;
  position: relative;
}

.box::after {
  content: "\f0fc";
  font-family: FontAwesome;
  font-size: 100px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
<head>
  <meta charset="UTF-8">
  <title>Font Awesome With Pseudo-Elements</title>
<!--  Font Awesome 4.6.3 CDN  -->
  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.6.3/css/font-awesome.min.css">
</head>
<body>
  <h1>Font Awesome with Pseudo-Elements</h1>
  <div class="box"></div>
</body>
...