im是類unix系統里最常用的編輯器之一,有很多常用的操作命令,如果能熟練使用,一定會提高自己的輸入速度,接下來整理了常用的命令。 |
打開關閉
代碼相關
移動光標
編輯
查找
替換
外部&&內部命令替換
選項設置
代碼格式化
原文來自:http://www.codeceo.com/article/vim-common-operating-commands.html
本文地址: https://www.linuxprobe.com/vim-mingling.html編輯員:姜顯赫,審核員:逄增寶
本文原創地址:https://www.linuxprobe.com/vim-mingling.html
篇我們來談論vim一個相當重要的東西——自動命令。
從編程的角度來看,自動命令有點類似于事件響應,或者回調函數之類。當外部發生某些事件的時候,自動執行事先定義好的一組命令。
定義一個自動命令的格式如下
autocmd type pattern cmd
說了這么多,我們以一個例子來說明:
當我們使用 vim 打開一個不存在的文件,如果直接退出,我們會發現它并沒有被保存。因為打開一個不存在的文件時 vim 并沒有真的在磁盤中創建這么一個文件,它僅僅新開了一個緩沖區,當執行寫命令的時候才真正會創建文件。我們使用 q! 退出的話,它是不會往文件中寫的
我們來試試修改這一行為,打開新文件的時候就創建,也就是打開一個新文件的時候就執行寫操作。打開新文件的事件使用 BufNewFile 來表示。這里我們不限定文件格式,因此 pattern 這塊就使用 * 來表示,執行的命令是 :w 來寫入。
:autocmd BufNewFile * w
自動命令可以監聽的事件類型主要有以下幾種
這些只是 vim 龐大事件中的一小部分,想要了解其他的事件,可以使用 :help autocmd-events
我們可以同時綁定多個事件,事件之間使用逗號作為分割即可,例如我們想要在寫入或者加載HTML文件之前對其進行自動排版,那么就可以使用如下代碼
:autocmd BufReadPost,BufWritePre *.html normal gg=G
自動命令它是在事件觸發時,執行命令。相當于我們在命令模式下手動輸入命令。在之前介紹命令模式的時候說到過,要在命令模式下使用普通模式的操作可以使用 normal。gg表示將光標移動到第一行,=G表示從當前光標到最后一行執行自動排版的操作。
我們在 html 文件中輸入
<html>
<body>
<div>
<div>
<p>hello!</p>
</div>
</div>
</body>
</html>
執行 :w之后我們發現它自動排版了。或者我們也可以使用 :edit打開一個排版混亂的HTML文件,會發現vim自動為它排版了。
或者我們再舉一個例子,我們在之前設置了自動換行功能,因為在一般的編程語言中,一行代碼寫太長確實不是一個好習慣。但是像 markdown 或者 html 這種用來寫文檔的標記語言,難免會出現很長的文本,這個時候再設置自動換行就有點不合適了,我們可以使用下面的語句來針對這兩種文檔來消除
:autocmd BufNewFile, BufReadPost *.html setlocal nowrap
這里我們使用 BufNewFile和 BufReadPost,因為我們需要對新創建的和已存在的 html文件都啟用該設置。
這種類型的事件可以說是我們最常用的,通過這個事件配合 setlocal 可以很方便地針對不同的編程語言做不同的設置
例如我們將上述取消 HTML 自動換行的代碼做一個改寫,改寫成使用 FileType
:autocmd FileType html setlocal nowrap
又或者我們可以根據不同的語言,定義一個快捷鍵快速添加注釋
:autocmd FileType python nnoremap <buffer> <localleader>c I#<esc>
:autocmd FileType javascript nnoremap <buffer> <localleader>c I//<esc>
在輸入完命令之后,我們新打開一個 js或者 python文件,就可以直接測試
我們也可以結合之前介紹過的本地縮寫的定義,針對不同的文件類型定義不同的縮寫,例如
:autocmd FileType c iabbrev <buffer> main int main(int argc, char* argv[])
:autocmd FileType python iabbrev <buffer> main if __name__ == "__main__":
針對不同語言快速填充main函數。
我們結合FileType 事件和縮寫似乎可以針對不同語言定義出對應的代碼片段,這個也就是有的編輯器提供的 code snippet 的功能,結合插件我們可以使用 vim 定義出更加強大的代碼片段
已經討論了自動命令的這么多東西了,各位小伙伴可能已經掌握了甚至已經開始迫不及待想往配置文件里面添加內容了。但是在 lua中該怎么使用自動命令呢?先別著急,自動命令相關內容還沒討論完,先容我賣個關子,我們在后面來討論如何在 lua中添加自動命令吧。
我們暫時不講如何在 lua 中添加自動命令,這里我們先嘗試啟用 init.vim 文件。我們在里面加入一行
autocmd BufWrite * sleep 200m
然后我們保存并使用 :source $MYVIMRC啟用
好像也沒什么變化是不是。別著急,我們多次執行 :source $MYVIMRC。然后再執行保存操作。是不是發現vim越來越慢了。這是怎么回事呢?
我們每次執行 :source $MYVIMRC 的時候,vim 不會丟棄原有的設置,只會重頭再來讀取并加載新的設置,有點像文件的追加。在多次加載配置文件的時候,vim 已經創建了多個自動命令了。隨著加載次數的增多,vim 中保存了多個休眠的自動命令了。所以 vim 會變得越來越卡。
你可能會說,誰沒事閑著一直加載配置文件玩啊,而且也沒有人會寫延時吧。但是想想這個場景是不是像我們在反復修改并測試配置的時候會做的操作。雖然我們不會做延時,但是加載配置或者加載插件也是要時間的,插件有的也會執行自動命令,如果數量大起來了,自然會影響vim的啟動速度。
我們該如何處理這個問題呢?
vim中給出的解決辦法是將自動命令放到一個用戶命名的組中,組成一個自動命令組。
使用關鍵字 augroup 來創建一個自動命令組。例如我們可以創建下面的自動命令組
:augroup testgrp
: autocmd BufWrite * echom "hello1"
: autocmd BufWrite * echom "hello2"
:augroup END
直接在命令行輸入這么些東西太麻煩了,我們還是在 init.vim 中輸入。啟用之后我們再來執行保存操作接著,執行 :message 命令來查看日志,發現有兩條打印
我們再來修改一下配置文件或者在命令行輸入添加下面一句
:augroup testgrp
: autocmd BufWrite * echom "hello3"
:augroup END
我們先退出vim,再打開,然后執行保存操作,再看看日志里面有幾條輸出呢?
答案可能會另各位百思不得其解,它會打印三條。并不是各位想象的那樣,同名的組發生覆蓋。這里它也會發生追加現象,將同一組的多個命令組合在一起。既然用不用組都會追加,那么我要它有何用,我還多寫了這么多代碼。別著急,我們慢慢往下看。
分組一個是為了劃分模塊,第二個原因就是我們可以使用 autocmd! 來清除同一組之前的命令。
例如我們將上述命令修改為
:augroup testgrp
: autocmd!
: autocmd BufWrite * echom "hello3"
:augroup END
這個時候再次測試,我們發現它只會打印一條語句了。
但是這里如果我們將它放在不同組的時候,情況就又發生變化了
:augroup testgrp
: autocmd BufWrite * echom "hello1"
: autocmd BufWrite * echom "hello2"
:augroup END
:augroup testgrp1
: autocmd!
: autocmd BufWrite * echom "hello3"
:augroup END
我們發現在保存之后,它還是會打印3條語句
autocmd! 只會清除同一組之前的所有命令,而不同組的命令它不會生效。這就給我們按模塊劃分命名提供了便利。
之前我們通過綁定快捷鍵 <leader>ss來自動重新加載配置,學習了自動命令之后我們可以進一步的偷懶了,利用自動命令,我們可以做到只要配置文件被保存了,就自動加載。
:augroup NVIMRC
: autocmd!
: autocmd BufWritePost init.vim source %
:augroup END
這里我們先使用 autocmd!清除之前的加載操作。后面的自動命令中,我們使用 BufWritePost在配置文件保存到磁盤之后再來執行加載操作,保證從磁盤中加載到的配置文件與我們修改過后的保持一致。
自動命名在我們實現 vim 自動化編程的一個重要工具。甚至 vim 自身也有很多功能依靠它來實現,比如文件類型檢測。文件類型檢測我們將在下一章進行討論。
累點滴,匯成江海。咱們從最最基礎的PHP知識開始學習,一步一個腳印的開啟PHP的學習旅途吧。
請點擊右上角“關注”按鈕關注我們喲:跟著木辛老師學習PHP編程知識,變身快樂的編程達人吧~
同學們好呀!木辛老師又來了。
咱們在開始PHP的學習之前,需要先準備一個可以提供PHP服務的Web服務器。我們就復用木辛老師專欄中的一個教程,使用Homestead本地開發環境進行學習唄。
傳送門:《Laravel第一課:搭建Laravel開發環境》
也可以關注木辛老師的Laravel專欄喲:
大家配置好本地開發環境以后,還需要稍微設置一下,針對這個項目,在Homestead配置文件中作如下設置,
添加指向當前項目根目錄的配置:
sites: - map: learning_php.test to: /Code/zyoo/learning_php to: /Code/zyoo/learning_php
另外還需要在本機hosts文件中添加一個域名指向:
sudo vim /etc/hosts
并添加如下記錄:
192.168.10.10 learning_php.test
最后,添加一個測試文件:
php代碼
然后,打開瀏覽器,訪問域名查看頁面結果
執行效果
大家可以看到,我們已經可以成功的訪問到測試用的PHP文件了。
好了,萬事俱備,只需要學習了。那么,咱們開始吧~
幾乎絕大部分服務器端的腳本語言最初設計的應用場景之一就是處理HTML表單。木辛老師要翻出家底,將自己最心愛的在線圖書商城,用來作為學習PHP基礎知識的場景吧。
通過這個表單頁面,我們可以知道顧客訂購的商品,訂單的金額以及其他一些附屬信息。HTML代碼請看下方:
<html> <head> <title>木辛老師的PHP基礎入門教程</title> </head> <body> <form action="processorder.php" method="POST"> <table style="border: 0px;"> <tr style="background: #cccccc"> <td style="width: 150px;text-align:center;">圖書名稱</td> <td style="width: 50px;text-align:center;">數量</td> </tr> <tr> <td>PHP入門指南</td> <td><input type="text" name=“book_name_01" size="3" maxlength="3"/></td> </tr> <tr> <td>PHP和MySQL開發</td> <td><input type="text" name="book_name_02" size="3" maxlength="3"/></td> </tr> <tr> <td>Laravel入門</td> <td><input type="text" name="book_name_03" size="3" maxlength="3"/></td> </tr> <tr> <td colspan="2" style="text-align: center;"> <input type="submit" value="提交訂單"/> </td> </tr> </table> </form> </body> </html>
咱么直接通過瀏覽器訪問這個HTML頁面,看看效果:
頁面顯示
哈,簡單的頁面,我們已經開啟Web開發神秘旅程了。繼續加油!
大家可能注意到了一個細節:在html代碼的form表單部分,action屬性我們指向了一個php腳本:
<form action="processorder.php" method="POST”>
具體的PHP腳本的學習我們很快就能看到。這里只是稍微提一下,這個action屬性值就是用戶點擊“提交訂單”按鈕時將要請求的URL。
用戶在表單中輸入的數據,會以POST的方式,發送給URL指向的PHP文件進行處理。
那如何處理這個表單呢?又如何讓PHP代碼起作用的?
要處理這個表單,我們需要創建一個php文件,它的名字需要和form中action屬性的值保持一致。
那么,我們就創建一個名字叫做processorder.php的文件吧。
代碼可以先這么寫,看看是否能起作用哈:
<html> <head> <title>訂單處理結果</title> </head> <body> <h1> 木辛老師的在線圖書館</h1> <h2> 訂單處理結果通知</h2> <?php echo '<p>訂單已處理完成</p>'; // 這里是PHP的代碼 ?> </body> </html>
保持文件,并刷新頁面。這個時候我們點擊“提交訂單”按鈕,效果如下:
php執行結果
大家可以看到,紅框部分就是通過PHP代碼輸出的結果。這樣,我們就實現了通過Web方式執行了PHP代碼的需求,這么一看PHP還是非常簡單的吧。
我們順便在看看這個頁面的源代碼吧,看一下PHP代碼如何在HTML頁面中完成任務的吧:
源代碼
通過頁面源碼,我們發現剛才寫的PHP代碼已經不見了,取而代之的是
<p>訂單已處理完成</p>
這是怎么回事呢?
這是因為PHP解釋器在腳本運行的時候,將該腳本的輸出替代了腳本自身的代碼,通過這種方式,就可以生成可以在任何瀏覽器上運行的HTML頁面了。也就是說,瀏覽器是不需要學會PHP的。
通過這段代碼,我們可以學習一些PHP的基礎知識:
第一種情況:在HTML中混寫PHP和HTML代碼,需要為php添加標記。PHP代碼會以“<?php”作為開始,以“?>”作為結束。這些符號就叫做PHP標記,它們主要用來告訴服務器PHP代碼的開始和截止,在這兩個起止符號之間的任何代碼,服務器都會以PHP語法來解析。
另一種情況:之后,我們寫純PHP的時候,每個文件也需要添加PHP標記。不過呢,結束標記可以省略,這也是很大一部分PHPer默認遵守的規則。
在PHP的開始和截止標記之間,就是PHP語句了,通過這些內容可以告訴PHP解釋器應該進行如何的操作,在我們這個例子里,通過:
echo '<p>訂單已處理完成</p>’;
使用echo語句完成了一個非常簡單的操作,僅是將echo后邊的字符串原樣打印到瀏覽器中。這里需要特別注意的一點就是每個PHP語句后邊都需要添加英文的分號作為語句的結束符,否則會出現錯誤,但是在這個html頁面中,因為只有一句代碼,忽略掉分號也是不會報錯的。
但是還是強烈建議大家養成習慣:每句PHP代碼結束都要以分號結尾喲!
一般情況下,為了讓代碼更加清晰和整潔,在編碼的過程中會添加一些空格,這些空格包括:回車換行、空格、制表符等都被認為是空格。
當然了,瀏覽器并不會在意你是否輸入了空格,同樣的PHP服務器端解析器也會忽略這些,這些空格僅是給編寫代碼的人看的。
但是,木辛老師還是再次強烈建議,在代碼的適當位置添加空格或者空行,這樣做可以很有效的提升代碼的可閱讀性,方便后期的維護工作。
最后在講講注釋,理論上在編程中出現頻率非常高的一個知識點。
為什么說理論上呢,因為這么重要的一個要點,在實際開發中很容易被廣大開發者忽略呢!
由于種種原因吧,開發者很不習慣在開發過程中寫非常詳盡的注釋,而且有時候在Git提交時也是草草的一筆帶過。這樣做的后果就是,若干時間后,當你再次拿到這段代碼,可能會花費更多的時間梳理它。
所以,善于寫注釋,也是提高生產效率的一種有效手段。
PHP解釋器同樣會在執行的時候忽略掉注釋,也就是說就好比像空格一樣,PHP解析器會跳過注釋,它只負責執行PHP代碼!
PHP腳本中的注釋比較豐富,有很多類似C語言的風格,比如:
多行注釋:
/* 這是 一個 多行 注釋 /*
可以看出來,多行注釋以 /*開始,以*/結束。同樣的和C語言是一樣的,多行注釋是不能嵌套的。
當然了,除了多行注釋之外,也支持單行注釋:
echo '<p>訂單已處理完成</p>'; // 這里是PHP的代碼
或者這種:
echo '<p>訂單已處理完成</p>’; #這里是PHP的代碼
不論采取哪種風格的注釋,在注釋符號之后的所有內容,PHP解釋器都會認識不需要處理的,這一點一定要注意呀!
好了,今天的課程咱就先講到這里。
小朋友們不要忘記關注我們喲 ,下期課程更精彩,請大家一起期待吧~
快樂編程,快樂成長,拜拜!
*請認真填寫需求信息,我們會在24小時內與您取得聯系。