您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“JS庫Highlightjs添加代碼行號的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“JS庫Highlightjs添加代碼行號的示例分析”這篇文章吧。
Highlightjs是一款優秀的代碼高亮Js組件,可以很方便地對各種語言編寫的代碼添加語法高亮樣式。
然而,Highlightjs默認是不包括顯示代碼行號(Line Number)這一特性的,不過可以通過簡單的JS代碼和CSS樣式表實現對Highlightjs的行號顯示功能。
參考博文鏈接: syntax-highlighting-with-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添加代碼行號的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。