欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS庫 Highlightjs 添加代碼行號的實現(xiàn)代碼

 更新時間:2017年09月13日 17:19:37   作者:在線瘋狂  
Highlightjs是一款優(yōu)秀的代碼高亮Js組件,可以很方便地對各種語言編寫的代碼添加語法高亮樣式。本文重點給大家介紹Highlightjs 添加代碼行號的實現(xiàn)代碼,需要的朋友參考下吧

Highlightjs是一款優(yōu)秀的代碼高亮Js組件,可以很方便地對各種語言編寫的代碼添加語法高亮樣式。

然而,Highlightjs默認是不包括顯示代碼行號(Line Number)這一特性的,不過可以通過簡單的JS代碼和CSS樣式表實現(xiàn)對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')。然后取得內(nèi)容并按照換行符split,我們可以得到代碼塊的行數(shù)。最后,我們構(gòu)建一個包含從數(shù)字1到行數(shù)n的行號列表,然后把這個列表追加到</pre>和</code>的閉合標簽之間。

此外通過添加適當?shù)腸ss樣式將行號列表渲染到代碼的左手邊緣。使用時請結(jié)合頁面樣式對下面的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行號顯示。

總結(jié)

以上所述是小編給大家介紹的JS庫 Highlightjs 添加代碼行號的實現(xiàn)代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 微信小程序時間軸組件的示例代碼

    微信小程序時間軸組件的示例代碼

    這篇文章主要介紹了微信小程序時間軸組件,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • Bootstrap零基礎(chǔ)入門教程(二)

    Bootstrap零基礎(chǔ)入門教程(二)

    Bootstrap 是一個用于快速開發(fā) Web 應用程序和網(wǎng)站的前端框架。Bootstrap 是基于 HTML、CSS、JAVASCRIPT 的。這篇文章主要介紹了Bootstrap零基礎(chǔ)入門教程(二) 的相關(guān)資料,非常不錯,具有參考借鑒價值,感興趣的朋友一起看下吧
    2016-07-07
  • Bootstrap每天必學之折疊(Collapse)插件

    Bootstrap每天必學之折疊(Collapse)插件

    Bootstrap每天必學之折疊(Collapse)插件,折疊插件可以很容易地讓頁面區(qū)域折疊起來,感興趣的小伙伴們可以參考一下
    2016-04-04
  • js 彈出新頁面避免被瀏覽器、ad攔截的一種新方法

    js 彈出新頁面避免被瀏覽器、ad攔截的一種新方法

    本文為大家介紹了使用js彈出新頁面同時避免被瀏覽器、ad攔截等,具體的實現(xiàn)方法如下,大家不妨參考參考
    2014-04-04
  • JavaScript基礎(chǔ)之文件上傳與下載的實現(xiàn)詳解

    JavaScript基礎(chǔ)之文件上傳與下載的實現(xiàn)詳解

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)文件上傳與下載功能的相關(guān)資料,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的小伙伴可以學習一下
    2023-01-01
  • JavaScript讓IE瀏覽器event對象符合W3C DOM標準

    JavaScript讓IE瀏覽器event對象符合W3C DOM標準

    IE瀏覽器event對象跟W3C實現(xiàn)的不一樣.所以自己封裝一個EventUtil類來讓IE瀏覽器的event對象與W3C一樣.
    2009-11-11
  • express異步函數(shù)異常捕獲示例詳解

    express異步函數(shù)異常捕獲示例詳解

    這篇文章主要給大家介紹了關(guān)于express異步函數(shù)異常捕獲的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • ES6新特性一: let和const命令詳解

    ES6新特性一: let和const命令詳解

    這篇文章主要介紹了ES6新特性中的let和const命令,結(jié)合實例形式分析了let和const命令的功能、使用方法與相關(guān)注意事項,需要的朋友可以參考下
    2017-04-04
  • js實現(xiàn)4個方向滾動的球

    js實現(xiàn)4個方向滾動的球

    本文主要介紹了js實現(xiàn)4個方向滾動球的實例,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • 詳解原生JavaScript實現(xiàn)jQuery中AJAX處理的方法

    詳解原生JavaScript實現(xiàn)jQuery中AJAX處理的方法

    這篇文章主要介紹了原生JavaScript實現(xiàn)jQuery中AJAX處理的方法,作者根據(jù)jQuery中一些對AJAX請求的處理方式來用原生API實現(xiàn),需要的朋友可以參考下
    2016-05-05

最新評論