Автоматическое оформление строк в HTML + CSS

Вопрос:

Я немного подумал об этой проблеме.

Можно ли, например, автоматически вставлять оформление строки после каждой строки (строки) в <div> или только в любом элементе, который содержит текст?

Например:

Это первая строка


Это вторая строка


Я заметил эту проблему, потому что подчеркивания не идеальны, а вставка div или разделяющих фрагментов текста в разных divs неудобна. Поскольку разные символы имеют различную ширину в типографике, если я использовал подчеркивания, две линии становятся неравномерными по ширине. Я не думаю, что таблицы могут автоматически разделять блок текста в две строки. Не без некоторого JQuery, делающего раскол.

Есть ли что-то, что позволит определить украшения линий после строк?

Мне нужно это, потому что текст в divs поступает из базы данных. Я не знаю длины каждой строки, и поэтому неудобно. Если я принимаю фиксированное количество символов в строке и начинаю измельчать слова пополам в конце строк,

как,

Hello World Wha


t вверх.


Благодарю!

Лучший ответ:

Возможно, вы можете подделать его с помощью эффекта » футеровки бумаги «. Вот один из таких результатов: http://css3.wikidot.com/blog:lined-paper-with-css

Я скопирую его здесь, чтобы сохранить его, если исходный сайт перемещается или опускается.

Техника довольно проста — все, что нам нужно, — это повторяющийся фоновый градиент, чтобы дать эффект линий на бумаге, а псевдоэлемент слева — дать правильное поле.

.paper {
    font: normal 12px/1.5 "Lucida Grande", arial, sans-serif;
    width: 300px;
    margin: 0 auto 10px;
    padding: 6px 5px 4px 42px;
    position: relative;
    color: #444;
    line-height: 20px;
    border: 1px solid #d2d2d2;

    background: #fff;
    background: -webkit-gradient(linear, 0 0, 0 100%, from(#d9eaf3), color-stop(4%, #fff)) 0 4px;
    background: -webkit-linear-gradient(top, #d9eaf3 0%, #fff 8%) 0 4px;
    background: -moz-linear-gradient(top, #d9eaf3 0%, #fff 8%) 0 4px;
    background: -ms-linear-gradient(top, #d9eaf3 0%, #fff 8%) 0 4px;
    background: -o-linear-gradient(top, #d9eaf3 0%, #fff 8%) 0 4px;
    background: linear-gradient(top, #d9eaf3 0%, #fff 8%) 0 4px;

    -webkit-background-size: 100% 20px;
    -moz-background-size: 100% 20px;
    -ms-background-size: 100% 20px;
    -o-background-size: 100% 20px;
    background-size: 100% 20px;

    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;

    -webkit-box-shadow: 0 1px 2px rgba(0,0,0,0.07);
    -moz-box-shadow: 0 1px 2px rgba(0,0,0,0.07);
    box-shadow: 0 1px 2px rgba(0,0,0,0.07);
}
.paper::before {
    content: '';
    position: absolute;
    width: 4px;
    top: 0;
    left: 30px;
    bottom: 0;
    border: 1px solid;
    border-color: transparent #efe4e4;
}

Чтобы все тексты правильно выравнивались по строкам, вам нужно специально объявить поля и высоты строк для всех текстовых элементов. Учитывая, что мы использовали размер фона 20px выше (т.е. 20px между строками), нам нужно использовать высоту строки (или эквивалентную высоту строки + margin) 20px.

.paper h1,
.paper h2 {
    font-size: 16px;
    line-height: 16px;
    margin: 0 0 4px;
}
.paper h3,
.paper h4,
.paper h5 {
    font-size: 14px;
    line-height: 16px;
    margin: 0 0 4px;
}
.paper h4,
.paper h5 {
    font-weight: normal;
}
.paper p {margin: 0 0 20px;}
.paper p:last-child {margin: 0;}
.paper ul {margin: 0 0 20px;}

Поддержка браузера

Он отлично работает в Webkit и Opera, и почти отлично работает в Firefox (правильные поля слева на 1 пиксель слишком короткие с одного конца). Теоретически он должен работать в IE10, но я его не тестировал.

Ответ №1

Другой способ — просто создать 1xN.png с 1 пикселем, заполненным внизу. и установите это как фоновое изображение. Где N равно высоте строки, как показано ниже:

1x16 <— Просто пятнышко.

Вы также можете преобразовать изображение в URI данных, если вы беспокоитесь о добавлении дополнительного запроса.

CSS

div {
background-image: url("1x16.png");
background-image: url();
line-height: 16px;
}

Оцените статью
TechArks.Ru
Добавить комментарий