在Git命令行一文中已經對Git的操做命令進行了簡單的介紹,可是理論知識過於枯燥,使得初學者在Git的使用上仍是會有很大的困難。雖然我更推薦使用Git Bash方式對Git進行操做,可是對於大部分只是想簡單地使用一下Git進行版本控制和團隊開發的朋友而言,可能仍然更加鍾情於可視化界面。因此本文對Git官方自帶的可視化工具Git Gui的使用進行介紹,儘可能作到圖文並茂,讓全部初探Git的朋友都可以快速入門,使用Git進行項目開發。html
首先,咱們打開Git GUI是這樣的一個界面,選擇第一項,新建版本庫。
git
而後選擇你須要進行版本管理的項目路徑,我選擇了一個LoginDemo的項目。
github
當你建立了版本庫的時候,你能夠在該項目的路徑下看見多了一個.git文件夾(設置了隱藏文件不可見的話看不見)
緩存
在Git Gui中,若是Unstaged Changes(未緩存的改動)中包含文件,則先點擊Stage Changed(stage,暫存區),將未緩存的改動加入緩存,再點擊Commit;不然須要先點擊Rescan掃描項目中進行過改動的文件。注:提交描述必需要填寫,否則沒法提交。
安全
提交成功後,咱們能夠在Repository->Visualize All Branches History中看到咱們提交的歷史記錄(這是提交到本地而不是提交到遠程服務器)。至此,本地版本庫就建立成功了。
服務器
上一步已經使用Git在本地創建起了版本庫,而後咱們須要將該項目提交到遠程服務器以便同事或其餘合做者共同參與開發。通常的開源項目使用github做爲遠程服務器。其實在本地簡歷版本庫後,只須要點擊push就能夠直接上傳。可是咱們尚未將本地的Git與github創建聯繫以及設置安全協議。ssh
首先,咱們須要在有一個本身的github賬戶,而後在github上新建一個repository,名字也叫作LoginDemo(能夠和本地項目名不同)。
工具
在Git Gui中,選擇Remote->add添加遠程服務器,遠程服務器信息有兩種填寫方式,填寫https地址或ssh地址,對應github項目的https和ssh地址,推薦使用ssh方式。fetch
這種方式須要輸入你的github賬戶和密碼,意味着經過這種方式你只可以操做本身的項目。
ui
這種方式須要進行受權設置,在Git Gui的菜單欄,點擊Help->Show SSH key->Generate SSH KEY建立密鑰。
而後在github的Personal settings中添加它,title隨意,能夠用Home,company等做爲標識來區別。
添加遠程服務器信息。
接下來,咱們即可以直接在Git Gui點擊push提交至遠程客戶端,刷新一下github,即可以看到項目已經在repository中了。
設想多人蔘與項目開發,每一個人都只push到遠程,徹底不顧其餘成員的進度,這樣的開發模式無疑是有問題的。咱們最好的作法是,每次push到遠程的時候,先從遠程把目前進度fetch下來,在和本身目前項目進度merge後,再將它push到遠程。打開Git Gui,在菜單欄中選擇Remote->Fetch from->LoginTest,即可以從遠程服務器更新到本地,可是還沒有與本身當前項目合併。
從遠程fetch後,選擇Git Gui的Merge->Local Merge進行合併,選擇Tracking Branch。
若是本地有一個方法名叫findUser,而遠程服務器中該方法的名字改變了,例如變成了findPassword,則合併遇到衝突,能夠右鍵空白部分選擇保留本地版本或遠程版本進行合併(圖中綠色的代碼表示衝突部分)。
在Git Gui的主界面選擇克隆已有版本庫。
Source Location即github中項目的地址,和第二部分(將項目提交到遠程)中同樣,能夠選擇https地址或ssh地址,Target Directory是在本地存放該項目的路徑。點擊Clone,成功從github將項目克隆到本地。