欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JS库 Highlightjs 添加代码行号的实现代码

程序员文章站 2022-09-08 12:14:34
highlightjs是一款优秀的代码高亮js组件,可以很方便地对各种语言编写的代码添加语法高亮样式。 然而,highlightjs默认是不包括显示代码行号(line n...

highlightjs是一款优秀的代码高亮js组件,可以很方便地对各种语言编写的代码添加语法高亮样式。

然而,highlightjs默认是不包括显示代码行号(line number)这一特性的,不过可以通过简单的js代码和css样式表实现对highlightjs的行号显示功能。

参考博文链接:

javascript代码:

//numbering for pre>code blocks
$(function(){
  $('pre code').each(function(){
    var lines = $(this).text().split('\n').length - 1;
    var $numbering = $('<ul/>').addclass('pre-numbering');
    $(this)
      .addclass('has-numbering')
      .parent()
      .append($numbering);
    for(i=1;i<=lines;i++){
      $numbering.append($('<li/>').text(i));
    }
  });
});

实际上很简单,首先找到代码块$('pre code')。然后取得内容并按照换行符split,我们可以得到代码块的行数。最后,我们构建一个包含从数字1到行数n的行号列表,然后把这个列表追加到</pre>和</code>的闭合标签之间。

此外通过添加适当的css样式将行号列表渲染到代码的左手边缘。使用时请结合页面样式对下面的css做出相应修改。

pre {
  position: relative;
  margin-bottom: 24px;
  border-radius: 3px;
  border: 1px solid #c3ccd0;
  background: #fff;
  overflow: hidden;
}
code {
 display: block;
 padding: 12px 24px;
 overflow-y: auto;
 font-weight: 300;
 font-family: menlo, monospace;
 font-size: 0.8em;
}
code.has-numbering {
  margin-left: 21px;
}
.pre-numbering {
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  padding: 12px 2px 12px 0;
  border-right: 1px solid #c3ccd0;
  border-radius: 3px 0 0 3px;
  background-color: #eee;
  text-align: right;
  font-family: menlo, monospace;
  font-size: 0.8em;
  color: #aaa;
}

通过上面的js代码和css样式表,即可完成简单易用的highlightjs行号显示。

总结

以上所述是小编给大家介绍的js库 highlightjs 添加代码行号的实现代码,希望对大家有所帮助