git安装

git初始化一个仓库

  • 命令:git init;

    • 想在哪个目录创建.git目录,就是哪个目录打开工具然后写命令.
    • 一般是在项目的根目录执行这个命令.
  • 配置用户名 : git config user.name "testName"
  • 配置邮箱 : git config user.email "test@sina.com"
  • 查看配置信息: git config --list

把代码提交到仓库中

  • 1.先把代码添加到暂存区(就相当于放到仓库门口)

    • 命令:git add 文件路径
    • 示例:git add ./reademe.md
    • 可以使用git add .这个命令,批量把当前目录下所有修改过的文件添加到暂存区。
  • 2.把暂存区的文件提交仓库里
    • 命令: git commit -m "注释"
    • 示例: git commit -m "我们添加了一个新的功能"
    • -m 表示指定一个字符串,作为提交的说明(相当于注释);
  • 合并add 与commit 命令
    • git commit -a -m "这是使用合并添加与提交的操作";
    • 这里-a参数表明把所有修改后的文件一起添加到暂存区.(只是对修改后的文件有效,对于新添加的文件没有作用)

查看工作区状态

  • 命令:git status

添加忽略文件

  • 在项目中有一些文件是不需要提交的,我们需要把它忽略掉
  • 需要在.git文件夹所在目录新建一个名为git dig的文件
    然后在这个文件中写上需要被忽略的文件的路径。
    示例: /css/a.css
    : /css/*.css
    : /a.html

比对文件差异

  • 命令: git diff

    • 用来比较工作区内容与最近一次提交的内容的区别
    • 如果暂存区没有文件,就会将工作与代码与最近一次提交对比
  • 命令:git diff --cached 比较暂存区的文件和仓库中文件的区别
  • 对比之前某两次提交的文件的差异
    • 命令:git diff [版本号1] [版本号2] [想比较的文件路径]

查看日志

  • 命令:git log,可以查看每一次提交的日志
  • 命令:git log --oneline 表示使用简洁的形式输出提交日志

版本回退

  • 命令:git reset --hard Head~1

    • 这是将代码回退到上上一次提交时的状态
  • 命令:git reset --hard Head~2
    • 回退到上上上次
  • 命令:git reset --hard Head~0
    • 回退到上次提交时的状态,~0可以省略
  • 命令:git reset --hard 版本号
    • 通过每次提交时生成的版本号来回退版本
  • 通过git reflog命令可以查看之前所有版本切换的操作记录,可以通过这个命令得到的版本号回退到指定的版本。

创建分支

  • 命令:git branch [分支名]

    • 创建一个新分支
  • 命令:git branch
    • 查看当前所有的分支

切换分支

  • 命令:git checkout [分支名]

    • 切换分支后可以在切换后的分支中进行正常的操作

合并分支

  • 命令:git merge [分支名]

    • git会将指定的分支合并到当前分支.

删除分支

  • 命令:git branch -d [分支名]

    • 删除指定分支,-d参数表示要执行删除操作

git提交中的冲突

  • 如果git不能自动合并分支,就会有冲突,我们需要手动解决冲突,然后再次提交

把代码push到服务器时需要先pull一下

  • 在pull之后如果远程的代码与本地的代码有冲突,git会先自动合并冲突,如果不能自动合并,就必需我们手动去处理冲突。

从服务器上pull代码到本地

  • 如果本地没有.git目录,需要先初始化一下。
  • 命令:git pull [远程服务器地址] [远程的分支]

上传代码到git服务器(push)

  • 命令:git push [远程服务器地址] [远程服务器的分支]

    • 示例:git push https://github.com/test002.git master
  • 上传时可以使用一些简化的命令
    • 将远程服务器地址写成变量的形式

      • git remote add [变量名] [远程服务器地址]
      • 示例:git remote add origin https://github.com/test002.git
      • 这样之后就可以直接使用origin来代替git push 后面写的地址了
        git push origin master
  • 还可以尽一步简化
    • 在push时加上-u参数,就会默认建立本地当前分支与远程指定分支的关联,下一次push时就不需要输入分支名了git push origin;

死板的git命令使用方式,只在新手阶段推荐使用。

  • 1每次想要提交代码,先执行“git pull”。如果失败,走到步骤2。如果成功,直接到步骤13
  • 2调用"git stash"保存自己的本次修改(如果有新增文件,需要先"git add *",再执行“git stash”)
  • 3调用git pull,系统会自动合并代码,如果有冲突,也会提示conflict(仔细看这句话执行后的返回)
  • 4如果不只是dist里面的文件有冲突,则用编辑器打开,解决冲突(这个步骤没有把握可以求助其他人,或者冲突相关人)
  • 5如果只有dist里面的文件有冲突,重新通过gulp来生成即可。
  • 6git stash list
  • 7git pull
  • 8git stash apply stash@{0}
  • 9git status
  • 10git add .
  • 11git commit -m “xxx”
  • 12git push
  • 13再用“git add *”来添加所有改动代码,然后“git commit -m '这里是注释'”提交,并“git push”推送到线上

Mac 安装插件失败

xxxx.app已损坏,打不开.你应该将它移到废纸篓

解决方法就是临时改变Mac系统安全设置:打开  系统偏好设置 -> 安全性与隐私,修改为任何来源

如果系统版本是macOS Sierra 10.12的话会看不到这个选项,解决办法是:打开终端,执行sudo spctl --master-disable即可。

git 的一般使用的更多相关文章

  1. Git 子模块 - submodule

    有种情况我们经常会遇到:某个工作中的项目需要包含并使用另一个项目. 也许是第三方库,或者你 独立开发的,用于多个父项目的库. 现在问题来了:你想要把它们当做两个独立的项目,同时又想在 一个项目中使用另 ...

  2. Git 在团队中的最佳实践--如何正确使用Git Flow

    我们已经从SVN 切换到Git很多年了,现在几乎所有的项目都在使用Github管理, 本篇文章讲一下为什么使用Git, 以及如何在团队中正确使用. Git的优点 Git的优点很多,但是这里只列出我认为 ...

  3. Git与Repo入门

    版本控制 版本控制是什么已不用在说了,就是记录我们对文件.目录或工程等的修改历史,方便查看更改历史,备份以便恢复以前的版本,多人协作... 一.原始版本控制 最原始的版本控制是纯手工的版本控制:修改文 ...

  4. Git Bash的一些命令和配置

    查看git版本号: git --version 如果是第一次使用Git,你需要设置署名和邮箱: $ git config --global user.name "用户名" $ gi ...

  5. 在Ubuntu 16.10 安装 git 并上传代码至 git.oschina.net

    1. 注册一个账号和创建项目 先在git.oschina.net上注册一个账号和新建一个project ,如project name 是"myTest". 2.安装git sudo ...

  6. 史上最详细git教程

    题外话 虽然这个标题很惊悚,不过还是把你骗进来了,哈哈-各位看官不要着急,耐心往下看 Git是什么 Git是目前世界上最先进的分布式版本控制系统. SVN与Git的最主要的区别 SVN是集中式版本控制 ...

  7. [版本控制之道] Git 常用的命令总结(欢迎收藏备用)

    坚持每天学习,坚持每天复习,技术永远学不完,自己永远要前进 总结日常开发生产中常用的Git版本控制命令 ------------------------------main-------------- ...

  8. 【解决方案】Myeclipse 10 安装 GIT 插件 集成 步骤 图解

    工程开发中,往往要使用到集成GIT ,那么下面说说插件安装步骤 PS:以Myeclipse 10 为例,讲解集成安装步骤. ----------------------main------------ ...

  9. git 命令

    切换仓库地址: git remote set-url origin xxx.git切换分支:git checkout name撤销修改:git checkout -- file删除文件:git rm  ...

  10. git亲测命令

    一.Git新建本地分支与远程分支关联问题 git checkout -b branch_name origin/branch_name 或者 git branch --set-upstream bra ...

随机推荐

  1. Netty 启动过程源码分析 (本文超长慎读)(基于4.1.23)

    前言 作为一个 Java 程序员,必须知道Java社区最强网络框架-------Netty,且必须看过源码,才能说是了解这个框架,否则都是无稽之谈.今天楼主不会讲什么理论和概念,而是使用debug 的 ...

  2. 并发编程 —— Timer 源码分析

    前言 在平时的开发中,肯定需要使用定时任务,而 Java 1.3 版本提供了一个 java.util.Timer 定时任务类.今天一起来看看这个类. 1.API 介绍 Timer 相关的有 3 个类: ...

  3. 浅谈sql中的in与not in,exists与not exists的区别以及性能分析

    1.in和exists in是把外表和内表作hash连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询,一直以来认为exists比in效率高的说法是不准确的.如果查询的两个表 ...

  4. JAVA项目工具包集合

    本文包括工具的下载以及配置,持续更新中…… 1 JDK 官网:https://www.oracle.com 下载:https://www.oracle.com/technetwork/java/jav ...

  5. APP中内嵌H5页面为什么不能下载?

    在APP中内嵌H5页面,若页面上存在下载链接,没有任何反应,为什么呢? 原因是app中内嵌的H5页面是WebView解析的,什么是WebView呢? 在Android手机中内置了一款高性能webkit ...

  6. 分布式Session一致性解决方案有哪些?

    1.使用cookie代替session(不安全,不推荐使用) 2.使用数据库存储session(效率低,不推荐使用) 3.使用nginx反向代理ip绑定方法,同一个ip只能在同一台服务器上进行访问(不 ...

  7. 关于Mysql数据库的知识总结

    2017年6月8日,天气阴.心情晴. 连续做梦两个晚上了,昨晚竟然梦见一个很长时间不联系的初中同学了,早上上班的路上聊了聊.女孩现在出差在贵州,风景秀美的地方.我说“你现在生活很滋润”.女孩说“那是你 ...

  8. 【webpack】webpack.base.conf.js基础配置

    var path = require('path') // node路径模块 var utils = require('./utils') // 对vue-loader对于css预编译一些提取的工具模 ...

  9. Python 基于Python实现邮件发送

    基于Python实现邮件发送   by:授客 QQ:1033553122 测试环境: Python版本:Python 2.7   注:需要修改mimetypes.py文件(该文件可通过文章底部的网盘分 ...

  10. 使用redis 处理高并发场景

    1.原理: 当同一个用户获取锁之后,会让该用户一直持有锁.同样 的用户再次获取,会根据原子性 ,lock返回true. /** * 获取锁(非公平锁), 默认获取超时为2分钟 */ public bo ...