如何修改vim插件vimwiki中Vimwiki2HTML的一些細節(jié)
問題描述
vimwiki默認的Vimwiki2HTML命令,會把%toc轉(zhuǎn)換為當(dāng)前wiki條目的目錄,但是會把二級目錄id轉(zhuǎn)換為toc_1.1(id中含有點號),而為了使用bootstrap-scrollspy實現(xiàn)滾動偵測(參考:如何實現(xiàn)網(wǎng)頁滾動偵測以及頂端固定導(dǎo)航欄),id中不能用點號。
請問:
怎么能讓vimwiki生成的html文件中目錄id不含點號,比如用toc_1_1代替toc_1.1。怎么能讓生成的目錄中<ul>標(biāo)簽有屬性class='nav',這個也是為了使用bootstrap-scrollspy。vimwiki的幫助手冊里這樣寫道:
vimwiki-option-custom_wiki2html------------------------------------------------------------------------------Key Default value~custom_wiki2html ’’Description~The full path to an user-provided script that converts a wiki page to HTML.Vimwiki calls the provided |vimwiki-option-custom_wiki2html| script from thecommand-line, using ’!’ invocation.The following arguments, in this order, are passed to the|vimwiki-option-custom_wiki2html| script:1. force : [0/1] overwrite an existing file2. syntax : the syntax chosen for this wiki3. extension : the file extension for this wiki4. output_dir : the full path of the output directory, i.e. ’path_html’5. input_file : the full path of the wiki page6. css_file : the full path of the css file for this wikiFor an example and further instructions, refer to the following script:$VIMHOME/autoload/vimwiki/customwiki2html.shTo use the internal wiki2html converter, use an empty string (the default).我水平有限,不能直接寫一個外部的腳本,想?yún)⒖枷聉imwiki默認的腳本是什么樣子,但是不知道internal wiki2html converter的腳本在哪里。
問題解答
回答1:現(xiàn)在有兩種方法:
1. 用sed批量處理;用sed修改vimwiki生成的html,使其合乎規(guī)范,腳本如下:
sed -i ’N;s/<p class='toc'>n<ul>/<p class='toc'>n<ul class='nav'>/ ; s/toc_([0-9]*).([0-9]*)/toc_1_2/g’ ~/Documents/wiki_html/cs_html/*.html ~/Documents/wiki_html/life_html/*.html ~/Documents/wiki_html/original_html/*.html ~/Documents/wiki_html/*.html
注意:sed N命令把偶數(shù)行添加在奇數(shù)行的緩沖區(qū),因此<p class='toc'>需要放在奇數(shù)行。
2. 修改autoload/vimwiki/html.vim文件,如下:
if level > plevel call add(toc, ’<ul class='nav'>’) elseif level < plevel let plevel = s:close_list(toc, plevel, level) endif
和
for l in range(1, h_level-1) let h_number .= a:id[l].’_’ endfor
感謝themacropodus@gmail.com 在 Can I modified the internal wiki2html... 的回答。
相關(guān)文章:
1. html5 - ElementUI table中el-table-column怎么設(shè)置百分比顯示。2. python - 使用readlines()方法讀取文件內(nèi)容后,再用for循環(huán)遍歷文件與變量匹配時出現(xiàn)疑難?3. 對mysql某個字段監(jiān)控的功能4. css3 - less或者scss 顏色計算的知識應(yīng)該怎么學(xué)?或者在哪里學(xué)?5. 注冊賬戶文字不能左右分離6. javascript - table列過多,有什么插件可以提供列排序和選擇顯示列的功能7. css - 網(wǎng)頁div區(qū)塊 像蘋果一樣可左右滑動 手機與電腦8. javascript - 數(shù)組的過濾和渲染9. html - vue項目中用到了elementUI問題10. JavaScript事件
