Центрировать текст в css border-треугольник в электронной почте - PullRequest
1 голос
/ 07 июля 2019

Я пытаюсь сгенерировать треугольник, используя границы CSS в электронном письме, и поместить в него динамический текст (числа), но я хочу установить его в центр треугольника, и я не могу использовать позиционирование, поскольку он удаляется изinline css

Я попытался поместить div для треугольника css и текстового промежутка в контейнер div и выровнять его по позиции - не сработало

<div style="<%= MailComponents.create_style('display' => 'inline-block', 'width' => '2px', 'height' => '0px', 'border-radius' => '4px' ,'border-left' => '20px solid transparent', 'border-right' => '20px solid transparent' ,'border-bottom => '30px solid #FC577A', 'color' => '#fff', 'vertical-align' => 'middle', 'line-height' => '28px', 'margin-top' => '-10px') %>">
            <span style="<%= MailComponents.create_style('position' => 'relative', 'left' => '-8px','vertical-align' => 'middle', ) %>">
              <%= some dynamically generated number %>
            </span>
          </div>

попытался использовать этот трюк

http://jsfiddle.net/VScFS/57/

не помогло. Мне интересно, можно ли это сделать с помощью таблиц

1 Ответ

1 голос
/ 07 июля 2019

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.container {
  display: grid;
  grid-template-columns: auto;
  justify-content: center;
  align-items: center; 
}

.wrapper {
  background: #000;
  width: 200px;
  height: 200px;
  -webkit-clip-path: polygon(0% 87%, 50% 0%, 50% 0%, 100% 87%);
  clip-path: polygon(0% 87%, 50% 0%, 50% 0%, 100% 87%);
}
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width">
  <title>JS Bin</title>
</head>
<body>
<div class="container">
  <div class="wrapper">
  </div>
</div>
</body>
</html>

Используйте display: grid в родительском классе и justify-content: center; , чтобы выровнять его по центру по горизонтали!Для справки вы можете посмотреть на https://www.w3schools.com/cssref/pr_grid.asp эту ссылку.Надеюсь, это поможет

...