摘要:是一個(gè)上古神器,剛剛接觸的同學(xué)可能很難駕馭,本篇文章主要帶領(lǐng)大家快速入門(mén),并持續(xù)分享當(dāng)前流行的一些安裝新手指南教程移動(dòng)光標(biāo)向前移動(dòng)兩個(gè)單詞向前移動(dòng)到第個(gè)單詞的末尾移動(dòng)到行首當(dāng)前行的末尾文件第一行文件最后一行行號(hào)指定行跳轉(zhuǎn)回之前的位置返回
Vim 是一個(gè)上古神器,剛剛接觸的同學(xué)可能很難駕馭,本篇文章主要帶領(lǐng)大家 快速入門(mén),并 持續(xù)分享 當(dāng)前流行的一些 vim-plugin安裝
sudo apt-get install vim // Ubuntu新手指南
vimtutor // vim 教程移動(dòng)光標(biāo)
# hjkl # 2w 向前移動(dòng)兩個(gè)單詞 # 3e 向前移動(dòng)到第 3 個(gè)單詞的末尾 # 0 移動(dòng)到行首 # $ 當(dāng)前行的末尾 # gg 文件第一行 # G 文件最后一行 # 行號(hào)+G 指定行 #退出+o 跳轉(zhuǎn)回之前的位置 # +i 返回跳轉(zhuǎn)之前的位置
#刪除進(jìn)入正常模式 # :q! 不保存退出 # :wq 保存后退出
# x 刪除當(dāng)前字符 # dw 刪除至當(dāng)前單詞末尾 # de 刪除至當(dāng)前單詞末尾,包括當(dāng)前字符 # d$ 刪除至當(dāng)前行尾 # dd 刪除整行 # 2dd 刪除兩行修改
# i 插入文本 # A 當(dāng)前行末尾添加 # r 替換當(dāng)前字符 # o 打開(kāi)新的一行并進(jìn)入插入模式撤銷(xiāo)
# u 撤銷(xiāo) #復(fù)制粘貼剪切+r 取消撤銷(xiāo)
# v 進(jìn)入可視模式 # y 復(fù)制 # p 粘貼 # yy 復(fù)制當(dāng)前行 # dd 剪切當(dāng)前行文件
# :e! 強(qiáng)制刷新該文件 #查找+g 顯示當(dāng)前行以及文件信息
# / 正向查找(n:繼續(xù)查找,N:相反方向繼續(xù)查找) # ? 逆向查找 # % 查找配對(duì)的 {,[,( # :set ic 忽略大小寫(xiě) # :set noic 取消忽略大小寫(xiě) # :set hls 匹配項(xiàng)高亮顯示 # :set is 顯示部分匹配替換
# :s/old/new 替換該行第一個(gè)匹配串 # :s/old/new/g 替換全行的匹配串 # :%s/old/new/g 替換整個(gè)文件的匹配串折疊
# zc 折疊 # zC 折疊所有嵌套 # zo 展開(kāi)折疊 # zO 展開(kāi)所有折疊嵌套執(zhí)行外部命令
# :!shell 執(zhí)行外部命令字體
#分屏- 縮小 # shift + 放大 # 0 還原
$ Ctrl+W v // 左右 $ Ctrl+W s // 上下 # 移動(dòng)光標(biāo) $ Ctrl+W h/j/k/l // 左/上/下/右 # 移動(dòng)分屏 $ Ctrl+W H/J/K/L // 左/上/下/右 # 修改屏幕尺寸 $ Ctrl+W =/+/-基本配置
.vimrc 是 Vim 的配置文件,需要我們自己創(chuàng)建
cd touch .vimrc取消備份
set nobackup set noswapfile文件編碼
set encoding=utf-8查找
set ic set hls set is顯示行號(hào)
set number顯示光標(biāo)當(dāng)前位置
set ruler設(shè)置縮進(jìn)
set cindent set tabstop=2 set shiftwidth=2突出顯示當(dāng)前行
set cursorline左下角顯示當(dāng)前 vim 模式
set showmode代碼折疊
set nofoldenable主題
syntax enable set background=dark colorscheme solarized
altercation/vim-colors-solarized
Anthony25/gnome-terminal-colors-solarized
插件配置使用 vim-plug 管理插件
樹(shù)形目錄Plug "scrooloose/nerdtree" Plug "jistr/vim-nerdtree-tabs" Plug "Xuyuanp/nerdtree-git-plugin" autocmd vimenter * NERDTree map:NERDTreeToggle let NERDTreeMinimalUI = 1 let NERDTreeShowHidden = 1 let g:nerdtree_tabs_open_on_console_startup = 1 let g:nerdtree_tabs_focus_on_files = 1 let g:NERDTreeIndicatorMapCustom = { "Modified" : "?", "Staged" : "?", "Untracked" : "?", "Renamed" : "?", "Unmerged" : "═", "Deleted" : "?", "Dirty" : "?", "Clean" : "??", "Ignored" : "?", "Unknown" : "?" } # o 打開(kāi)關(guān)閉文件或目錄 # e 以文件管理的方式打開(kāi)選中的目錄 # t 在標(biāo)簽頁(yè)中打開(kāi) # T 在標(biāo)簽頁(yè)中打開(kāi),但光標(biāo)仍然留在 NERDTree # r 刷新光標(biāo)所在的目錄 # R 刷新當(dāng)前根路徑 # X 收起所有目錄 # p 小寫(xiě),跳轉(zhuǎn)到光標(biāo)所在的上一級(jí)路徑 # P 大寫(xiě),跳轉(zhuǎn)到當(dāng)前根路徑 # J 到第一個(gè)節(jié)點(diǎn) # K 到最后一個(gè)節(jié)點(diǎn) # I 顯示隱藏文件 # m 顯示文件操作菜單 # C 將根路徑設(shè)置為光標(biāo)所在的目錄 # u 設(shè)置上級(jí)目錄為根路徑 # ctrl + w + w 光標(biāo)自動(dòng)在左右側(cè)窗口切換 # ctrl + w + r 移動(dòng)當(dāng)前窗口的布局位置 # :tabc 關(guān)閉當(dāng)前的 tab # :tabo 關(guān)閉所有其他的 tab # :tabp 前一個(gè) tab # :tabn 后一個(gè) tab # gT 前一個(gè) tab # gt 后一個(gè) tab
scrooloose/nerdtree
vim-nerdtree-tabs
nerdtree-git-plugin
代碼,引號(hào),路徑補(bǔ)全Plug "Valloric/YouCompleteMe" Plug "Raimondi/delimitMate" Plug "Shougo/deoplete.nvim", { "do": ":UpdateRemotePlugins" }
Valloric/YouCompleteMe
Raimondi/delimitMate
Shougo/deoplete.nvim
語(yǔ)法高亮,檢查Plug "sheerun/vim-polyglot" Plug "w0rp/ale" let g:ale_linters = { "javascript": ["eslint"], "css": ["stylelint"], } let g:ale_fixers = { "javascript": ["eslint"], "css": ["stylelint"], } let g:ale_fix_on_save = 1 let g:ale_sign_column_always = 1 let g:ale_sign_error = "●" let g:ale_sign_warning = "?" nmap(ale_previous_wrap) nmap (ale_next_wrap)
w0rp/ale
sheerun/vim-polyglot
文件,代碼搜索,打開(kāi)最近打開(kāi)的文件Plug "rking/ag.vim" Plug "kien/ctrlp.vim" Plug "vim-scripts/mru.vim" let g:ag_highlight=1 let g:ag_working_path_mode="r" # :Ag! content set wildignore+=*.zip,*.exe let g:ctrlp_map = "" let g:ctrlp_custom_ignore = { "dir": "v[/](node_modules|DS_Store|dist|build|coverage)|(.(git|hg|svn)$)", "file": "v.(exe|so|dll)$", } # : 切換匹配模式 # or , :在新的 tab 中打開(kāi) let MRU_Exclude_Files = "^/tmp/.*|^/var/tmp/.*" let MRU_Window_Height = 15 # :MRU
kien/ctrlp.vim
ggreer/the_silver_searcher
rking/ag.vim
vim-scripts/mru.vim
加強(qiáng)版狀態(tài)欄Plug "itchyny/lightline.vim" let g:lightline = { "colorscheme": "powerline", "active": { "left": [ [ "mode", "paste" ], [ "gitbranch", "readonly", "filename", "modified", "helloworld" ] ], "right": [ [ "lineinfo" ], [ "percent" ], [ "fileformat", "fileencoding", "filetype" ] ] }, "component": { "helloworld": "Hello, 楓上霧棋!" }, "component_function": { "gitbranch": "fugitive#head" }, }
itchyny/lightline.vim
代碼注釋Plug "scrooloose/nerdcommenter" #c 注釋/取消注釋 # cc // 注釋 # cm 只用一組符號(hào)注釋 # cA 在行尾添加注釋 # c$ /* 注釋 */ # cs /* 塊注釋 */ # cy 注釋并復(fù)制 # ca 切換 // 和 /* */ # cu 取消注釋 let g:NERDSpaceDelims = 1 let g:NERDDefaultAlign = "left" let g:NERDCustomDelimiters = { "javascript": { "left": "http://", "leftAlt": "/**", "rightAlt": "*/" }, "less": { "left": "/**", "right": "*/" } } let g:NERDAltDelims_javascript = 1 let g:NERDDefaultNesting = 0
scrooloose/nerdcommenter
gitPlug "airblade/vim-gitgutter" Plug "tpope/vim-fugitive"
airblade/vim-gitgutter
tpope/vim-fugitive
MarkdownPlug "suan/vim-instant-markdown" Plug "junegunn/goyo.vim" Plug "amix/vim-zenroom2" let g:instant_markdown_slow = 1 let g:instant_markdown_autostart = 0 # :InstantMarkdownPreview # :Goyo
suan/vim-instant-markdown
junegunn/goyo.vim
amix/vim-zenroom2
EmmetPlug "mattn/emmet-vim" let g:user_emmet_leader_key="" let g:user_emmet_settings = { "javascript.jsx" : { "extends" : "jsx", }, }
mattn/emmet-vim
html 5Plug "othree/html5.vim"
othree/html5.vim
css 3Plug "hail2u/vim-css3-syntax" Plug "ap/vim-css-color" augroup VimCSS3Syntax autocmd! autocmd FileType css setlocal iskeyword+=- augroup END
hail2u/vim-css3-syntax
ap/vim-css-color
JavaSciptPlug "pangloss/vim-javascript" let g:javascript_plugin_jsdoc = 1 let g:javascript_plugin_ngdoc = 1 let g:javascript_plugin_flow = 1 set foldmethod=syntax let g:javascript_conceal_function = "?" let g:javascript_conceal_null = "?" let g:javascript_conceal_this = "@" let g:javascript_conceal_return = "?" let g:javascript_conceal_undefined = "?" let g:javascript_conceal_NaN = "?" let g:javascript_conceal_prototype = "?" let g:javascript_conceal_static = "?" let g:javascript_conceal_super = "Ω" let g:javascript_conceal_arrow_function = "?" let g:javascript_conceal_noarg_arrow_function = "?" let g:javascript_conceal_underscore_arrow_function = "?" set conceallevel=1
pangloss/vim-javascript
js-beautifyPlug "maksimr/vim-jsbeautify" autocmd FileType html noremap:call HtmlBeautify()
js-beautify
ReactPlug "mxw/vim-jsx" let g:jsx_ext_required = 0
mxw/vim-jsx
PrettierPlug "prettier/vim-prettier", { "do": "yarn install", "for": ["javascript", "typescript", "css", "less", "scss", "json", "graphql", "markdown"] } let g:prettier#config#bracket_spacing = "true" let g:prettier#config#jsx_bracket_same_line = "false" let g:prettier#config#trailing_comma = "es5" let g:prettier#autoformat = 0 autocmd BufWritePre *.js,*.jsx,*.mjs,*.ts,*.tsx,*.css,*.less,*.scss,*.json,*.graphql,*md PrettierAsync # :Prettier
prettier/vim-prettier
自動(dòng)規(guī)范化中文排版Plug "hotoo/pangu.vim" # :Pangu
hotoo/pangu.vim
總結(jié)最后,提供 to-vim-tmux-zsh 倉(cāng)庫(kù)可供參考,其中,除包含 vim 的配置,還有 tmux 和 zsh 的分享
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/24980.html
摘要:我們都知道和都是文本編輯器中的上古神器,你也許用,配合完成過(guò)大型或者的開(kāi)發(fā),你也許配合過(guò)其他插件,完成過(guò),代碼的開(kāi)發(fā),但是很少有人試過(guò)的開(kāi)發(fā)吧,畢竟的框架包含了很多東西,以及天生很長(zhǎng)的名字,讓我們沒(méi)辦法把此神器用起來(lái),今天我就來(lái)給大家講下 我們都知道 Vim 和 Emacs 都是文本編輯器中的上古神器,你也許用 ctags,cscopes 配合 Vim 完成過(guò)大型 C 或者 C++ 的...
摘要:原文地址實(shí)戰(zhàn)指南四命令是下的一個(gè)文本編輯器。你已經(jīng)見(jiàn)過(guò)中的,沒(méi)錯(cuò),這些就是來(lái)自于命令。當(dāng)你希望顯示某行,輸入命令,顯示器上才會(huì)顯示那行。而控制這個(gè)顯示器顯示文本的命令行工具,就是。 原文地址:Vim實(shí)戰(zhàn)指南(四):ex命令 Introduction ex是Unix下的一個(gè)文本編輯器。至于為什么突然講到這個(gè),那是因?yàn)関i就是ex的visual mode。你已經(jīng)見(jiàn)過(guò)vi中的:w, :q!,...
摘要:歡迎來(lái)我的個(gè)人站點(diǎn)性能優(yōu)化其他優(yōu)化瀏覽器關(guān)鍵渲染路徑開(kāi)啟性能優(yōu)化之旅高性能滾動(dòng)及頁(yè)面渲染優(yōu)化理論寫(xiě)法對(duì)壓縮率的影響唯快不破應(yīng)用的個(gè)優(yōu)化步驟進(jìn)階鵝廠大神用直出實(shí)現(xiàn)網(wǎng)頁(yè)瞬開(kāi)緩存網(wǎng)頁(yè)性能管理詳解寫(xiě)給后端程序員的緩存原理介紹年底補(bǔ)課緩存機(jī)制優(yōu)化動(dòng) 歡迎來(lái)我的個(gè)人站點(diǎn) 性能優(yōu)化 其他 優(yōu)化瀏覽器關(guān)鍵渲染路徑 - 開(kāi)啟性能優(yōu)化之旅 高性能滾動(dòng) scroll 及頁(yè)面渲染優(yōu)化 理論 | HTML寫(xiě)法...
閱讀 1599·2021-11-18 10:02
閱讀 1788·2021-09-04 16:40
閱讀 3242·2021-09-01 10:48
閱讀 933·2019-08-30 15:55
閱讀 1950·2019-08-30 15:55
閱讀 1438·2019-08-30 13:05
閱讀 3095·2019-08-30 12:52
閱讀 1669·2019-08-30 11:24