GitHub gần đây đã được phát hành miễn phí cho các team, đây là một tin tuyệt vời cho tất cả các lập trình viên chúng ta.
Tất cả chúng ta đều có các lệnh Git mà chúng ta sử dụng lặp đi lặp lại hàng ngày. Nhưng điều gì sẽ xảy ra nếu mình nói với bạn rằng có một số lệnh Git ít người biết đến nhưng có thể giúp công việc của bạn dễ dàng hơn.
Trong bài viết này, chúng ta sẽ đi qua 7 lệnh Git ít người biết hữu ích nhất.
Một số trong số này có thể bạn đã từng sử dụng, một số có thể mới đối với bạn và một số bạn có thể bạn không nghĩ rằng nó có thể làm được. 😳 Nhưng bạn sẽ không bao giờ biết cho đến khi bạn thử chúng!
#1: git add -p
Bạn có thể đã sử dụng lệnh git add <file>
hoặc git add .
nhiều lần trước đây. Nhưng lệnh git add -p
làm được gì?
Bạn đã bao giờ muốn chỉ commit một phần của tệp chứ không phải toàn bộ?
Vậy thì hãy sử dụng git add -p
. Nó cho phép một commit ngắn gọn hơn.
Khi lệnh này chạy, chúng ta sẽ được hỏi về 'hunks'. 'Hunks' là các đoạn mã mà chúng ta sẽ quyết định phải làm gì với chúng.
Bạn sẽ thấy câu hỏi, "State this hunk [y, n, g, a, d, e,?]?" ở cuối terminal.
Các chữ cái có nghĩa là những điều sau:
-
y
: Đồng ý
-
n
: Không đồng ý
-
g
: Chọn một Hunk khác để chuyển đến
-
a
: Phần này và tất cả các phần khác trong tệp này
-
d
: Không tạo thành phần này hoặc bất kỳ phần nào khác trong tệp này
-
e
: Chỉnh sửa Hunk hiện tại theo cách thủ công
-
?
: In ra sự trợ giúp
Khi hoàn thành tất cả các 'Hunk', chúng ta sẽ có thể thấy rằng commit của chúng ta đã sẵn sàng và chúng ta có thể tiếp tục push!
#2: git commit -amend
Khi commit, đôi khi chúng ta có thể nhấn 'Enter' quá nhanh và mắc lỗi đánh máy ở đâu đó trong thông báo commit.
Nhưng đừng lo!
Có một lệnh git cho phép chúng ta sửa lỗi đánh máy hoặc thông báo commit bị gắn nhãn sai.
Trong ví dụ của chúng ta, giả sử chúng ta chạy git commit -m 'fixing a typeo'
và nhấn Enter.
Ngay sau đó, chúng ta nhận ra rằng lỗi 'typeo'
(lẽ ra là typo
) trong thông báo commit.
Bây giờ, hãy chạy lệnh git commit —amend -m 'fixing a typo'
thực hiện sửa lỗi.
Giờ đây, khi chúng ta push commit của mình, sếp của chúng ta sẽ không thấy lỗi đánh máy 'fixing a typeo
' của chúng ta nữa. :D
#3: git reset --soft HEAD~1
Lệnh git reset
có nhiều thứ mà bạn có thể theo dõi, như là "soft".
Xóa commit cuối cùng khỏi branch hiện tại, nhưng vẫn giữ các thay đổi!
Khi sử dụng lệnh git reset —soft HEAD ~ 1
, nó sẽ xóa commit cuối cùng khỏi branch hiện tại.
Nhưng điều thú vị về lệnh này là các thay đổi sẽ không biến mất! Tất cả các thay đổi sẽ ở trong cây làm việc!
Trong ví dụ dưới đây, chúng ta đã commit và sau đó chạy lệnh git reset —soft HEAD ~ 1
.
Cố gắng push commit này sẽ không hoạt động, vì vậy khi chạy git push origin master
, thì nhận về thông báo "không có gì để đẩy lên cả".
Nó thực sự đã thực hiện commit cuối cùng của chúng ta và giữ các thay đổi của chúng ta trong tệp!
#4: git checkout
Lệnh này có thể giúp ích rất nhiều khi có nhiều thứ xảy ra trong một commit và bạn không muốn commit toàn bộ.
Nó giống như git cherry-pick
(mà chúng ta sẽ nói đến tiếp theo) nhưng thay vì 'cherry-picking' toàn bộ commit, chúng ta thậm chí còn đi sâu hơn vào một branch và chỉ chọn một tệp cụ thể mà chúng ta muốn merged.
Hãy xem nó được thực hiện như thế nào!
Chọn một tệp cụ thể từ một branch và đưa nó vào branch hiện tại.
Trong khi ở master
, chúng ta có thể chạy lệnh git checkout kapehe-test index.html
để lấy tệp đã commit cụ thể đó trong branch cụ thể đó và chuyển nó sang chế độ master để cuối cùng push.
Điều đó khá dễ hiểu khi các thay đổi của một branch cụ thể có nhiều thay đổi và chúng ta chỉ tìm kiếm một tệp để test hoặc push.
#5: git cherry-pick
Trong lệnh này, chúng ta có thể chọn một branch cụ thể có một commit và kéo nó vào một branch khác.
Giả sử chúng ta có một branch kapehe-test
và chúng ta đã commit tất cả các thay đổi của mình.
Có một branch khác, chúng ta sẽ chỉ sử dụng master
nhưng đây có thể là bất kỳ branch nào và chúng ta muốn lấy commit của kapehe-test
.
Bằng cách sử dụng lệnh git cherry-pick kapehe-test
, chúng ta có thể đưa toàn bộ commit đó vào một branch khác.
Mang toàn bộ commit từ một branch sang branch khác.
#6: git stash
Lệnh git stash
dành cho các thay đổi chưa được commit trong tệp.
Giả sử chúng ta có một loạt thay đổi đối với một tệp nhưng cần quay lại và kiểm tra một số thứ trước khi chúng ta commit và push chúng, nếu không chúng ta chưa sẵn sàng thực hiện các thay đổi của mình.
Đó là lúc lệnh git stash
phát huy tác dụng.
Lưu các thay đổi chưa commit và lưu trữ chúng để sử dụng sau này. Nó thực sự hữu ích khi bạn muốn commit và push nhưng chưa sẵn sàng thực hiện các thay đổi kể từ lần commit cuối cùng.
#7: git help
Còn có rất nhiều lệnh git khác nhau ở ngoài kia.
Và ngay trước khi chúng ta bắt đầu chạy các lệnh git, nếu biết chính xác nó sẽ làm gì với mã của chúng ta thì sẽ tốt hơn.
Nếu chúng ta chỉ chạy lệnh git help
thì chúng ta sẽ nhận được giải thích về lệnh ngay tại trong terminal của chúng ta.
Nhưng chỉ thế thì đã đủ chưa?
Chạy lệnh git help -w <command>
sẽ đưa chúng ta trực tiếp đến trang web mà chúng ta có thể đọc tất cả những giải thích về lệnh đó.
Tóm lại
Git rất mạnh mẽ, nó giúp ích cho công việc của chúng ta rất là nhiều. Mình hy vọng 7 lệnh git có thể bạn chưa biết này sẽ giúp bạn sử dụng git hiệu quả hơn một chút.
> Xem ngay: Bảng cửu chương Git.
---
HỌC VIỆN ĐÀO TẠO CNTT NIIT - ICT HÀ NỘI
Học Lập trình chất lượng cao (Since 2002). Học làm Lập trình viên. Hành động ngay!
Đc: Tầng 3, 25T2, N05, Nguyễn Thị Thập, Cầu Giấy, Hà Nội
SĐT: 02435574074 - 0914939543
Email: hello@niithanoi.edu.vn
Fanpage: https://facebook.com/NIIT.ICT/
#niit #niithanoi #niiticthanoi #hoclaptrinh #khoahoclaptrinh #hoclaptrinhjava #hoclaptrinhphp #java #php #python