Пост

Нумерация строк внутри тэгов pre,code используя css и javascript

Тег <pre> предназначен для отображения предварительно отформатированного текста, обычно кода, в виде, близком к оригинальному. Он позволяет сохранить пробелы и форматирование текста, как было указано в исходном коде. Тег используется для выделения кода в HTML-документе. Он не изменяет форматирование текста, но позволяет отличить код от обычного текста.

Что бы добавить нумерацию строк, после тэгов </code> и </pre> нужно вставить javascript

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<script language="javascript">
(function() {
    var pre = document.getElementsByTagName('pre'),
        pl = pre.length;
    for (var i = 0; i < pl; i++) {
        pre[i].innerHTML = '<span class="line-number"></span>' + pre[i].innerHTML + '<span class="cl"></span>';
        var num = pre[i].innerHTML.split(/\n/).length;
        for (var j = 0; j < num; j++) {
            var line_num = pre[i].getElementsByTagName('span')[0];
            line_num.innerHTML += '<span>' + (j + 1) + '</span>';
        }
    }
})();
</script>

Чтобы нумерация шла слева, перед строками исходника, нужно настроить оформление через css, например

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
body {
  background-color:white;
  padding:50px 50px;
}

pre {
  background-color:#eee;
  overflow:auto;
  margin:0 0 1em;
  padding:.5em 1em;
}

pre code, pre .line-number {
  font:normal normal 12px/14px "Courier New",Courier,Monospace;
  color:black;
  display:block;
}

pre .line-number {
  float:left;
  margin:0 1em 0 -1em;
  border-right:1px solid;
  text-align:right;
}

pre .line-number span {
  display:block;
  padding:0 .5em 0 1em;
}

pre .cl {
  display:block;
  clear:both;
}

На этой странице можно увидеть пример вывода исходного кода с нумерацией строк

Авторский пост защищен лицензией CC BY 4.0 .

© IT Draft. Некоторые права защищены.