這篇文章主要為大家展示了“JS庫(kù)Highlightjs添加代碼行號(hào)的示例分析”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“JS庫(kù)Highlightjs添加代碼行號(hào)的示例分析”這篇文章吧。
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、小程序制作、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了康巴什免費(fèi)建站歡迎大家使用!
Highlightjs是一款優(yōu)秀的代碼高亮Js組件,可以很方便地對(duì)各種語(yǔ)言編寫的代碼添加語(yǔ)法高亮樣式。
然而,Highlightjs默認(rèn)是不包括顯示代碼行號(hào)(Line Number)這一特性的,不過(guò)可以通過(guò)簡(jiǎn)單的JS代碼和CSS樣式表實(shí)現(xiàn)對(duì)Highlightjs的行號(hào)顯示功能。
參考博文鏈接: 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)); } }); });
實(shí)際上很簡(jiǎn)單,首先找到代碼塊$('pre code')。然后取得內(nèi)容并按照換行符split,我們可以得到代碼塊的行數(shù)。最后,我們構(gòu)建一個(gè)包含從數(shù)字1到行數(shù)n的行號(hào)列表,然后把這個(gè)列表追加到</pre>和</code>的閉合標(biāo)簽之間。
此外通過(guò)添加適當(dāng)?shù)腸ss樣式將行號(hào)列表渲染到代碼的左手邊緣。使用時(shí)請(qǐng)結(jié)合頁(yè)面樣式對(duì)下面的css做出相應(yīng)修改。
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; }
通過(guò)上面的js代碼和css樣式表,即可完成簡(jiǎn)單易用的Highlightjs行號(hào)顯示。
以上是“JS庫(kù)Highlightjs添加代碼行號(hào)的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)站題目:JS庫(kù)Highlightjs添加代碼行號(hào)的示例分析
網(wǎng)頁(yè)鏈接:http://aaarwkj.com/article22/igcpcc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營(yíng)銷、企業(yè)建站、域名注冊(cè)、虛擬主機(jī)、微信公眾號(hào)、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)