Я хочу центрировать свой всплывающий текст так, чтобы он был посередине ... Но я не могу? - PullRequest
0 голосов
/ 03 мая 2020

Название говорит само за себя. Мне нужна помощь с выравниванием всплывающего текста, я впервые публикую здесь, когда я ищу и попробую, но не могу найти никакого решения: (

У меня появляется всплывающее окно, когда я нажимаю кнопку, но не могу выровняйте POPUP ARROW с кнопкой.

Я не знаю, что еще могу сказать по этому поводу, но я не могу представить это, поскольку должен сказать что-то еще ...

Примечание: я Я не профессиональный программист.

<meta name="viewport" content="width=device-width, initial-scale=1">
<style>
/* Popup container - can be anything you want */
.popup {
  position: relative;
  display: inline-block;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* The actual popup */
.popup .popuptext {
  visibility: hidden;
  width: 500px;
  height: 500px; 
  background-color: #555;
  color: #fff;
  text-align: left;
  border-radius: 6px;
  padding: 8px 1;
  position: absolute;
  z-index: 1;
  bottom: 125%;
  left: 50%;
  margin-left: -80px;
}

/* Popup arrow */
.popup .popuptext::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -5px;
  border-width: 5px;
  border-style: solid;
  border-color: #555 transparent transparent transparent;
}

/* Toggle this class - hide and show the popup */
.popup .show {
  visibility: visible;
  -webkit-animation: fadeIn 1s;
  animation: fadeIn 1s;
}

/* Add animation (fade in the popup) */
@-webkit-keyframes fadeIn {
  from {opacity: 0;} 
  to {opacity: 1;}
}

@keyframes fadeIn {
  from {opacity: 0;}
  to {opacity:1 ;}
}
</style>
<body style="text-align:center">

	
    <div class="popup" onclick="myFunction()">
	<button class="button";">How to use?</button>
  	<span class="popuptext" id="myPopup">1. Press "Insert Token" and insert the tokens.txt</span>
</div>

<script>
// When the user clicks on div, open the popup
function myFunction() {
  var popup = document.getElementById("myPopup");
  popup.classList.toggle("show");
}
</script>

Ответы [ 2 ]

1 голос
/ 03 мая 2020

Надеюсь, это JSFiddle - это то, что вы ищете?

Ваша проблема была с margin-left на .popup .popuptext. Вы установили -80px, это должно быть половина ширины.

Редактировать

Я обновил скрипку, чтобы включить изменения, предложенные @Atul в комментарии ниже. margin-left: -250px был удален и заменен на transform: translateX(-50%).

0 голосов
/ 03 мая 2020

Сделайте одно, поместите его в центр через css

.popup-text{
     visibility: hidden;
     width: 500px;
     height: 500px; 
     background-color: #555;
     color: #fff;
     text-align: left;
     border-radius: 6px;
     padding: 8px;
     position: absolute;
     top:50%;
     left:50%;
     transform:translate(-50%,-50%);
     z-index: 1;
}

. Он также разместит ваш всплывающий текст в центре по вертикали и горизонтали.
, если вы просто хотите, чтобы он располагался по центру по вертикали, измените код последней 3 строки на этот код:

position:absolute;
left:50%;
transform:translateX(-50%); // You can event use margin-left:-250px b'cause you have fix 500px.
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...