vim搭配markdown实现实时预览

首先不得不再次感叹一下开源世界的强大!!!

首先要setup

  • 需要vim7.4,首先参考安装vim7.4

  • 安装gcc等编译工具
    yum -y install gcc+ gcc-c++

  • 安装node.js

cd /usr/local/src/ && \
wget http://nodejs.org/dist/v0.10.24/node-v0.10.24.tar.gz && \
tar zxvf node-v0.10.24.tar.gz && \
cd node-v0.10.24 && \
./configure --prefix=/usr/local/node/0.10.24 && \
make && \
make install && \
echo "export NODE_HOME=/usr/local/node/0.10.24" >> ~/.bashrc && \
source ~/.bashrc && \
echo "export PATH=$NODE_HOME/bin:$PATH" >> ~/.bashrc && \
source ~/.bashrc && \
node -v
yum install npm
npm config set strict-ssl false && \
npm -g install instant-markdown-d

这一步是安装 https://github.com/suan/instant-markdown-d 到node的库,
运行一下instant-markdown-d会发现,其实是运行的这个,
/usr/local/node/0.10.24/lib/node_modules/instant-markdown-d/instant-markdown-d

  • 我的linux机器上已经安装了xdg-utils和curl
    安装curl主要是因为 vim-instant-markdown/after/ftplugin/markdown/instant-markdown.vim
    会用到curl
function! s:refreshView()
    let bufnr = expand('<bufnr>')
    call s:systemasync("curl -X PUT -T - http://localhost:8090",
                \ s:bufGetLines(bufnr))
endfu
cd ~ && \
git clone git://github.com/suan/vim-instant-markdown.git && \
mkdir -p ~/.vim/after/ftplugin/markdown/ && \
cd vim-instant-markdown && \
cp after/ftplugin/markdown/instant-markdown.vim ~/.vim/after/ftplugin/markdown/
  • 不知道为什么两次 npm -g install instant-markdown-d 安装的包不一样啊!把第一次安装的能用的传到第二个上面
rm -rf /usr/local/node/1.1.1.1/lib/node_modules/instant-markdown-d && \
scp -r /usr/local/node/1.1.1.1/lib/node_modules/instant-markdown-d \
root@1.1.1.1:/usr/local/node/1.1.1.1/lib/node_modules
echo "filetype plugin on" >> ~/.vimrc && \
echo "let g:instant_markdown_open_to_the_world = 1" >> ~/.vimrc

启用插件
让插件在0.0.0.0监听,

vim README.md
netstat -antup | grep 8090

但是好像没用,
不过没关系,因为vim-instant-markdown/after/ftplugin/markdown/instant-markdown.vim
是在这个地方调用instant-markdown-d的

    let env = ''
    if g:instant_markdown_open_to_the_world
        let env .= 'INSTANT_MARKDOWN_OPEN_TO_THE_WORLD=1 '
    endif
    if g:instant_markdown_allow_unsafe_content
        let env .= 'INSTANT_MARKDOWN_ALLOW_UNSAFE_CONTENT=1 '
    endif
    if !g:instant_markdown_allow_external_content
        let env .= 'INSTANT_MARKDOWN_BLOCK_EXTERNAL=1 '
    endif

    call s:systemasync('instant-markdown-d', a:initialMDLines)
endfu

所以我们直接修改
/usr/local/node/0.10.24/lib/node_modules/instant-markdown-d/instant-markdown-d
把本地监听的也改为全内网监听即可

if (process.env.INSTANT_MARKDOWN_OPEN_TO_THE_WORLD) {
  // Listen on any interface.
  server.listen(8090, onListening).once('error', onServerError);
} else {
  // Listen locally.
  // server.listen(8090, '127.0.0.1', onListening).once('error', onServerError);
  server.listen(8090, onListening).once('error', onServerError);                                                                                         
}
  • 这样打开一个README.md之后,我们在运行netstat -antup | grep 8090就可以看到本机在8090端口监听啦,这样用chrome输入 本机IP:8090 就可以看到啦!
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 自从用了vim自后恨不得所有文字相关的写作都用vim来解决,最近开始接触markdown,所以网上搜了一圈mark...
    放开那老司机阅读 64,902评论 9 29
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,860评论 18 139
  • 偶然拜读到听风说币的一篇关于写评论的文章,其从“道”和“术”两个方面做了精彩的阐述。真是“世事通明皆学问,人情练达...
    上官非阅读 167评论 0 0
  • 1.XMPPStream: xmpp基础服务类;2.XMPPAutoPing 和 XMPPPing两个类: 心跳监...
    路漫漫其修远兮Wzt阅读 3,278评论 1 1
  • 在很久很久以前,在遥远的西方有一个平静的小村庄,那里的人们日出而作,日落而息,过着与世无争的生活。可是村民们平静的...
    小明是个饭盒阅读 1,502评论 0 50