L-образный контейнер

Я пытаюсь нарисовать следующий "L" образ с помощью CSS.

L shaped container div

Как я могу нарисовать эту фигуру, поэтому содержали текстовые потоки в этом L-образном контейнере?

Ответ 1

Так же:

HTML:

<div class="container">
    <div class="mask"></div>
     <p>Lorem ipsum dolor sit amet, consectetur adipisici elit, sed eiusmod tempor incidunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquid ex ea commodi consequat. Quis aute iure reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint obcaecat cupiditat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
</div>

CSS

.container
{
    border: 3px solid black;
}

.mask
{
    border-style: solid;
    border-width: 0 0 3px 3px;
    position: relative;
    float: right;
    clear: none;
    right: -3px;
    top: -3px;
    background-color: white;
    width: 50%;
    height: 4em;
}

Демо

Ответ 2

Вот еще одна версия, которая также предназначена для прозрачного и непрозрачного фона. По существу это улучшает принятый в настоящее время ответ.

В этом методе форма создается следующим образом:

  • Контейнер с нижней и левой границами, так как они являются единственными двумя границами, которые покрывают всю высоту/ширину контейнера.
  • Фон добавлен через linear-gradients для половины ширины и половины высоты контейнера. Фоны имеют размер, равный ширине границы, и расположены по мере необходимости в левом верхнем и нижнем правом углу.
  • Добавлен псевдоэлемент, который перемещается вправо и позиционируется по мере необходимости, чтобы он выглядел так, как будто форма напоминает "L". Псевдоэлемент имеет границы слева и снизу.

.container {
  box-sizing: border-box;
  position: relative;
  margin: 10px;
  border-left: 3px solid;
  border-bottom: 3px solid;
  height: 250px;
  /*height: auto;*/
  width: 400px;
  line-height: 20px;
  background: -webkit-linear-gradient(0deg, black 50%, transparent 50%), -webkit-linear-gradient(90deg, black 50%, transparent 50%);
  background: -moz-linear-gradient(90deg, black 50%, transparent 50%), -moz-linear-gradient(0deg, black 50%, transparent 50%);
  background: linear-gradient(90deg, black 50%, transparent 50%), linear-gradient(0deg, black 50%, transparent 50%);
  background-size: 100% 3px, 3px 100%;
  /*background-size: 100% 3px, 3px 122%;*/
  background-position: 0px 0px, 100% 100%;
  background-repeat: no-repeat;
}
.container:before {
  position: relative;
  float: right;
  right: 0px;
  top: 0px;
  content: '';
  background: transparent;
  height: 50%;
  /*height: 80px;*/
  width: 50%;
  border-left: 3px solid;
  border-bottom: 3px solid;
}
p {
  display: block;
  padding: 8px 8px;
}

/* Just for demo */

body {
  background: -webkit-linear-gradient(0deg, crimson, indianred, purple);
  background: -moz-linear-gradient(90deg, crimson, indianred, purple);
  background: linear-gradient(90deg, crimson, indianred, purple);
}
<div class="container">
  <p>Lorem ipsum dolor sit amet, consectetur adipisici elit, sed eiusmod tempor incidunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquid ex ea commodi consequat. Quis aute iure reprehenderit
    in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint obcaecat cupiditat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
</div>

Ответ 3

Вы можете использовать инструмент веб-дизайнера Google для создания сложных фигур с помощью HTML5-canvas and CSS.

Поскольку файл содержит много кода, предоставляя скрипту демонстрации, созданной с помощью Инструмента Google Web Designer

DEMO