网站首页 > 精选文章 正文
作者:Maxence Poutord
如果你觉得 git 很迷惑人,那么这份小抄正是为你准备的!
请注意我有意跳过了 git commit、git pull/push 之类的基本命令,这份小抄的主题是 git 的一些「高级」用法。
导航 —— 跳到之前的分支
git checkout -
查看历史
# 每个提交在一行内显示
git log --oneline
# 在所有提交日志中搜索包含「homepage」的提交
git log --all --grep='homepage'
# 获取某人的提交日志
git log --author="Maxence"
哎呀:之前重置了一个不想保留的提交,但是现在又想要回滚?
# 获取所有操作历史
git reflog
# 重置到相应提交
git reset HEAD@{4}
# ……或者……
git reset --hard <提交的哈希值>
哎哟:我把本地仓库搞得一团糟,应该怎么清理?
git fetch origin
git checkout master
git reset --hard origin/master
查看我的分支和 master 的不同
git diff master..my-branch
定制提交
# 编辑上次提交
git commit --amend -m "更好的提交日志"
# 在上次提交中附加一些内容,保持提交日志不变git add . && git commit --amend --no-edit
# 空提交 —— 可以用来重新触发 CI 构建
git commit --allow-empty -m "chore: re-trigger build"
squash 提交
比方说我想要 rebase 最近 3 个提交:
- git rebase -i HEAD~3
- 保留第一行的 pick,剩余提交替换为 squash 或 s
- 清理提交日志并保存(vi 编辑器中键入 :wq 即可保存)
pick 64d26a1 feat: add index.js
s 45f0259 fix: update index.js
s 8b15b0a fix: typo in index.js
修正
比方说想在提交 fed14a4c 加上一些内容。
git 提交分支
git add .
git commit --fixup HEAD~1
# 或者也可以用提交的哈希值(fed14a4c)替换 HEAD~1
git rebase -i HEAD~3 --autosquash
# 保存并退出文件(VI 中输入 `:wq`)
rebase 的时候在每个提交上执行命令
如果特性很多,一个分支里可能有多个提交。如果测试失败了,你希望能找到导致测试失败的提交。这时候你可以使用 rebase --exec 命令在每个提交上执行命令。
# 在最近 3 个提交上运行 `npm test` 命令
git rebase HEAD~3 --exec "npm test"
暂存
暂存不止是 git stash 和 git stash pop ;)
# 保存所有正在追踪的文件
git stash save "日志信息"
# 列出所有的暂存项
git stash list
# 获取并删除暂存项
git stash apply stash@{1}
git stash drop stash@{1}
# ……或使用一条命令……
git stash pop stash@{1}
清理
# 移除远程仓库上不存在的分支
git fetch -p
# 移除所有包含 `greenkeeper` 的分支
git fetch -p && git branch --remote | fgrep greenkeeper | sed 's/^.\{9\}//' | xargs git push origin --delete
GitHub = Git + Hub
我把 Hub 当成 git 的一个封装来用。你如果也想这么做,可以设置一个别名:alias git='hub'
# 打开浏览器访问仓库 url(仅限 GitHub 仓库)git browse
额外福利:我最喜爱的 git 别名
alias g='git'
alias glog='git log --oneline --decorate --graph'
alias gst='git status'
alias gp='git push'
alias ga='git add'alias gc='git commit -v'
#
alias yolo='git push --force'
# 每周站会汇报工作时用
git-standup() {
AUTHOR=${AUTHOR:="`git config user.name`"}
since=yesterday
if [[ $(date +%u) == 1 ]] ; then
since="2 days ago"
fi
git log --all --since "$since" --oneline --author="$AUTHOR"
}
来源:New Frontend网站
- 上一篇: 高德打车通用可编排订单状态机引擎设计
- 下一篇: Java高级面试题整理(java中高级面试技术问题)
猜你喜欢
- 2025-01-31 Java从零开始:不同系统JDK的安装及Java基本命令
- 2025-01-31 Visual Studio 2015 Update 1正式发布
- 2025-01-31 Java中生成随机数的4种方式(java中随机生成数字的方法)
- 2025-01-31 MySQL有哪些实现方式?何为插入,何为更新?
- 2025-01-31 微软:今日起,IE11正式封杀老旧ActiveX控件
- 2025-01-31 阿里Java三面:分布式延时任务方案解析,万字长文一篇点通你
- 2025-01-31 打开软件遇警告 解决方法并不难(软件打开异常是什么原因)
- 2025-01-31 手把手教你搭建一个基于Java的分布式爬虫系统「转」
- 2025-01-31 性能问题从发现到优化一般思路(性能问题是什么意思)
- 2025-01-31 讲真的,关于 Java 正则表达式,你具体知多少?
- 05-3022《Vue 入门教程》VueRouter 路由嵌套
- 05-30前端面试题-Vue 项目中,你做过哪些性能优化?
- 05-30超简 Vue3+elementPlus 后台管理系统
- 05-30还有前端不知道Electron的?手把手教你把Vue项目打包成桌面程序
- 05-30Nuxt最简入门,让vue项目快速被搜索引擎收录
- 05-30Mac上最美最好用软件系列
- 05-30AI编程小白必备|Cursor安装及配置教程
- 05-30好玩儿的编程语言——文言文编程语言
- 最近发表
- 标签列表
-
- 向日葵无法连接服务器 (32)
- git.exe (33)
- vscode更新 (34)
- dev c (33)
- git ignore命令 (32)
- gitlab提交代码步骤 (37)
- java update (36)
- vue debug (34)
- vue blur (32)
- vscode导入vue项目 (33)
- vue chart (32)
- vue cms (32)
- 大雅数据库 (34)
- 技术迭代 (37)
- 同一局域网 (33)
- github拒绝连接 (33)
- vscode php插件 (32)
- vue注释快捷键 (32)
- linux ssr (33)
- 微端服务器 (35)
- 导航猫 (32)
- 获取当前时间年月日 (33)
- stp软件 (33)
- http下载文件 (33)
- linux bt下载 (33)