git status?statu
s这个单词真心不好记。
git st
就表示git status
那就简单多了,当然这种偷懒的办法我们是极力赞成的。
st
就表示status
:
$ git config --global alias.st status
git st
看看效果。
co
表示checkout
,ci
表示commit
,br
表示branch
:
$ git config --global alias.co checkout
$ git config --global alias.ci commit
$ git config --global alias.br branch
$ git ci -m "bala bala bala..."
--global
参数是全局参数,也就是这些命令在这台电脑的所有Git仓库下都有用。
git reset HEAD file
可以把暂存区的修改撤销掉(unstage)
,重新放回工作区。既然是一个unstage
操作,就可以配置一个unstage
别名:
$ git config --global alias.unstage 'reset HEAD'
$ git unstage test.py
$ git reset HEAD test.py
git last
,让其显示最后一次提交信息:$ git config --global alias.last 'log -1'
git last
就能显示最近一次的提交:$ git last
commit adca45d317e6d8a4b23f9811c3d7b7f0f180bfe2
Merge: bd6ae48 291bea8
Author: 用户名 <邮箱>
Date: Thu Aug 22 22:49:22 2019 +0800
merge & fix hello.py
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
--global
是针对当前用户起作用的,如果不加,那只针对当前的仓库起作用。
$ cat .git/config
[core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
ignorecase = true
precomposeunicode = true
[remote "origin"]
url = git@github.com:用户名/learngit.git
fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
remote = origin
merge = refs/heads/master
[alias]
last = log -1
[alias]
后面,要删除别名,直接把对应的行删掉即可。
.gitconfig
中:
$ cat .gitconfig
[alias]
co = checkout
ci = commit
br = branch
st = status
[user]
name = Your Name
email = your@email.com