一些废话

本文的主旨是为初次接触Github的同学提供一个入门的教程,如果你已经是Github老鸟,可以忽略本文哦,另外本文只是抛砖引玉,其实最好的教程是官方文档!!!

Github目前虽然十分火热,但是对于第一次接触这一类产品的同学来说,上手还是有一定难度的

本文就聊一聊如何使用Github,相信读完本文,你一定可以掌握以下几点:

  • Github是什么
  • Github可以做什么
  • Git与Github的关系
  • 本地项目上传至Github
  • 克隆远程仓库修改后提交
  • 举一反三Github、Gitee、Coding

Github是什么

全球最大的同性交友平台--->全球最大的程序猿交流平台--->一个神奇的地方

Github是目前最火的网站之一,在这里很多的用户都是从事程序相关工作,又被戏称为全球最大的程序猿交流平台, 从最初仅活跃在程序员圈子中发展到现在各行各业的使用,经常用Github你就会发现,这真的是个神奇的地方,这里有很多五花八门,有趣的仓库。

那么Github到底是什么呢?

Wiki 百科上是这么说的

GitHub 是一个共享虚拟主机服务,用于存放使用Git版本控制的软件代码和内容项目。它由GitHub公司(曾称Logical Awesome)的开发者Chris Wanstrath、PJ Hyett和Tom Preston-Werner 使用Ruby on Rails编写而成。

官方是这么说的

GitHub is a code hosting platform for version control and collaboration. It lets you and others work together on projects from anywhere.

用我的工地英语翻译过来意思就是

GitHub是用于版本控制和协作的代码托管平台。它使您和其他人可以在任何地方共同处理项目。

虽然官方概括的很精简,但是过于官方,以至于我也一脸懵*,不过我们脑海里可以对她有以下几点印象:

  • 存放代码、存放项目
  • 版本控制
  • 托管平台
  • 共同处理项目

Github可以做什么

在了解了Github是什么后,如果你以为github就是个存代码的地方那你就太年轻了,你完全想不到全球网民的脑洞有多强大,Github都快玩出了花。

除了最基础的可用来存储和管理项目工程外,Github还可以做很多其他事情:

  • 网站
  • 个人博客
  • 说明文档
  • 管理配置文件
  • 收集资料
  • 面试简历
  • 托管编程环境
  • 写书、写小说
  • 资源共享
  • 招聘信息发布
  • 老师布置作业,学生交作业
  • 公益活动
  • 等等等....五花八门千奇百怪

Git与Github的关系

从GitHub的介绍上我们不难看出,GitHub托管的是Git代码仓库。

这时候可能又有同学想问“这个Git又是什么鬼?他和Github又有什么关系”

Git是一个分布式的版本控制系统,可以对项目进行版本管理。而GitHub可以托管各种git库,并提供一个web界面

Git只是一个源代码管理工具(管理代码的版本) 并不能实现代码的共享。

而我们将本地的Git库(使用Git版本控制的软件代码和内容项目)上传到Github上,通过GitHub实现共享,达到不同之间的协同工作

所以在正式使用Github之前,需要先学会使用Git管理项目工程,即学会版本控制

Git的命令大全和原理性知识本文不做拓展,大家如有兴趣可以去Git官方文档翻阅学习哦

本地项目上传至Github

在开始本节介绍前呢需要大家准备以下环境和账号:

  • Github账号
  • 本地电脑安装Git

在Github中创建新的仓库

直接进入创建仓库页面:https://github.com/new

或者通过按钮进入创建页面:

具体的创建步骤如下图所示:

创建成功后会跳转到如下页面:

仔细看图上,不难发现,他已经告诉你接下来该怎么做,如何创建一个新的存储库(create a new repository on the command line

下面我们按照他给的方式,来试一下看看效果~

配置本地Git环境

如果是第一次使用 Git,你需要设置署名和邮箱

$ git config --global user.name "用户名"
$ git config --global user.email "电子邮箱"

设置成功后在Github提交记录中就会显示本次提交人的信息

创建本地项目

创建一个用于托管在Github中的项目工程

创建本地文件夹

创建一个名为 GithubStudy 的文件夹

本地git仓库初始化

进入 GithubStudy 文件夹 右键打开git bash here,执行如下命令,进行本地git仓库初始化

git init

完成后在当前项目里面会有一个.git文件夹 是用来记录当前本地仓库(如果看不到需要勾上显示隐藏文件)

创建文件

在文件夹下创建一个README.md,其内容为:


### 1.学习使用Github:本地项目上传至Github

添加到暂存区

此时把将项目的修改全部添加到暂存区 ,意思就是保存此次的所有修改

GithubStudy 文件夹 右键打开git bash here,执行如下命令git add .(注意有点......)

ps: git add .:添加全部文件到暂存区,git add README.md:指定文件添加到暂存区

提交到本地仓库

把当前暂存区添加的文件提交到本地仓库(提交后就表示创建了一个代码的版本)

GithubStudy 文件夹 右键打开git bash here,执行如下命令 git commit -m '提交日志'

提交完成后就会把代码提交到.git文件夹(本地git仓库) 并且会自动创建一个代码的版本

指定远程服务器仓库

继续在git bash here中执行命令:git remote add origin {项目仓库地址}

注意:这里的项目仓库地址是你在github创建完新仓库时自动生成的,比如我刚刚创建后生成的是:https://github.com/larscheng/GithubStudy.git

执行完上述命令后,远程仓库的地址就指定好了,我们随时都可以推送项目

推送至Github

所有准备工作都已完成,现在就需要我们将项目推送至GitHub,你也可以理解为上传。

GithubStudy 文件夹下右键打开git bash here,执行如下命令 git push -u origin master

注:初次提交时,会需要验证你的Github用户名和密码,根据命令提示输入后即可完成推送

此时你再进入Github刚刚创建的仓库中,刷新页面后,看到的应该是如下的样子:

在线修改项目并提交

这里,我在项目中创建了一个新的文件夹名叫update.txt 修改操作可以参考如下动态图

拉取最新版本

此时我们本地的项目已经不是最新的了,如何进行版本同步,获取最新的代码呢,执行如下命令即可

git pull

执行成功后,本地代码即为最新咯

克隆远程仓库修改后提交

这一节,主要演示的是:当你已有一个github项目,如何将它克隆至本地,修改后推送至github

这里还是以GithubStudy项目为演示,在Github下该仓库的首页中复制仓库地址:

克隆

新建文件夹GithubStudyClone

GithubStudyClone 文件夹下右键打开git bash here,执行如下命令 git clone {项目仓库地址}

注意:这里的项目仓库地址是你在github创建完新仓库时自动生成的,比如我创建后生成的是:https://github.com/larscheng/GithubStudy.git,每个人的地址都会有所不同,记得替换哦

执行结果如下:

修改

修改文件README.md,在原有内容中加入如下信息:

### 2.学习使用Github:克隆远程仓库修改后提交

添加+提交+推送

修改完成后,执行如下三条命令,即可推送至GitHub

GithubStudyClone/GithubStudy 目录下右键打开git bash here,依次执行如下命令

git add .

git commit -m '修改README'

git push -u origin master

此时进入GitHub中查看GithubStudy,你会发现我们刚刚的修改已经生效

对比

上面对于Github的入门使用已经基本介绍完了,Github目前以被微软收入囊中,对于国内用户来说由于网络的原因访问Github时往往不是那么的顺畅。

那么国内是否有Github同类型的产品呢?答案当然是有的

  • 码云(gitee.com)是 OSCHINA.NET 推出的代码托管平台,支持 Git 和 SVN,提供免费的私有仓库托管。
  • Coding 是一个面向开发者的云端开发平台,目前提供代码托管,运行空间,质量控制,项目管理等功能。

这两款产品作为代码托管平台来说与Github几乎一样,都是优秀的托管平台。

如果你烦恼于GitHub的访问限制,那完全可以考虑使用Gitee、或者Coding

所以问题来了,产品都换了,那怎么用呢? GitHub我都是才学会,又要学Coding、Gitee

不用担心,操作一摸一样,你完全可以用上面Github讲解的操作流程来使用Gitee、Coding。

总结

本文不是Git的安装教程、也不是原理分析文章,本文旨在为初次接触Github的同学提供一个容易上手的中文演示

本文中也存在一些难点和坑点,例如

  • Git命令的使用
  • Github身份验证
  • Github的其他功能使用
  • 等等...

其实大家不用害怕,东西虽然多,但是都很好理解,当你遇到问题时要学会运用搜索引擎、学会阅读官方文档。

当然如果有问题也可以留言或者邮件联系我哦

如果阅读完本文后,你已经基本掌握了Github的使用,这里为大家提供一些高阶操作的文章:



萌新入门Github请看这里,学不会远程教的更多相关文章

  1. jmeter正则表达式,萌新入门篇

    @@@@@@@@@@@@ 透过现象看本质 jmeter中正则表达式对我们来说,就是一个工具,他可以帮助我们做的事就是从一堆数据中截取出我们想要的字段,比如从setcookie:DERF12456DAS ...

  2. python之萌新入门的第一天

    新人的挑战一:配置环境变量及正确地使用工具. 配置环境好难,照着教程做很简单,但是确定环境配置成功好难. 一开始运行helloworld程序的文件时一直出现SyntaxError:invaild sy ...

  3. 萌新入门之python基础语法

    首先我们先了解一些python最最基础的入门 1.标识符 定义:我们写代码的时候自己取得名字比如项目名,包名,模块名这些: 规范:1.数字/字母/下划线组成,不能以数字开头 2.起名字要见名知意 3. ...

  4. 萌新的IDEA_web开发笔记(未完)

    萌新IDEA_web开发笔记 按兴趣自己搞的网页: http://47.94.140.98:8080/ow_web/my_web/web/ 暂时还没做完. 部署在租的服务器上面,背景视频加载可能有点慢 ...

  5. Vue初识:一个前端萌新的总结

    一.前言 时隔三年,记得第一次写博客还是2015年了,经过这几年的洗礼,我也从一个后端的小萌新变成现在略懂一点点知识的文青.如今对于前端的东东也算有一知半解,个人能力总的来说,也能够独立开发产品级项目 ...

  6. 从Webpack源码探究打包流程,萌新也能看懂~

    简介 上一篇讲述了如何理解tapable这个钩子机制,因为这个是webpack程序的灵魂.虽然钩子机制很灵活,而然却变成了我们读懂webpack道路上的阻碍.每当webpack运行起来的时候,我的心态 ...

  7. 给萌新HTML5 入门指南

    本文由葡萄城技术团队原创并首发 转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. HTML5的发展改变了互联网技术趋势,前端热度依旧不减,所以对于应用开发人员 ...

  8. 带着萌新看springboot源码05

    上一节走了一遍从浏览器发出请求到得到向页面的流程,基本的功能是已经实现了.但是现在啊,我想自定义一个拦截器(拦截器可以做用户登录验证,如果登录了,就让你通过,如果没有登录,就重定向登录页面),这里就不 ...

  9. 萌新web前端从零开始(1)——计算机入门

    前言:这是一个萌新从零开始的学习之路,与大家分享自己的看法与见解,还请指出错误与遗漏点方便改正. 1.认识计算机. 计算机语言常见的有C,PHP,Ruby,Java,C#,Basic,JS,C++等, ...

随机推荐

  1. TensorFlow2.0极简安装(亲测有效)

    x相信每一个学习深度学习的人来说都知道Google的深度学习框架TensorFlow,估计每个人都想成为一个TF Boy(TensorFlow Boy).我也是这个想法,于是我踏上了安装TensorF ...

  2. Mybatis整合spring(适合小白)

    目录 1.整合思路 2.整合需要的jar包 3.整合的步骤 4.Dao的开发的两种实现方式 6.Dao的开发的实现方式总结图 @ Mybatis整合spring其实就是SSM框架中SM的整合集成. 1 ...

  3. asp.net core 从 3.0 到 3.1

    asp.net core 从 3.0 到 3.1 Intro 今天 .net core 3.1 正式发布了,.net core 3.1 正式版已发布,3.1 主要是对 3.0 的 bug 修复,以及一 ...

  4. 你真的了解foreach吗?

    引言 有C#基础的,当问到循环有哪些,会毫不犹豫的说出的for.do while.foreach及while这几种,但是到具体实际开发中,我们遇到一些问题,比如:到底选择哪种?为什么选择这种?哪种好像 ...

  5. VMware中linux虚拟机的安装

    打开安装的VMware 15,点击新建虚拟机 2.选择典型即可,点击下一步 3.选择“稍后安装操作系统”,点击下一步 4.选择想安的版本,点击下一步 5.设置虚拟机名称及安装位置(路径必须全英文!) ...

  6. fsockopen用feof读取http响应内容的一些问题

    在前面三个例子中,都有这么一段代码: while (!feof($fp)) { // 读取文件/数据 //$content .= fgets($fp, 128); //$line = fread($f ...

  7. java前端与后端怎么选??

    想做这个行业,就应该了解职能以及技能需求,这样学习才能更高效.我知道一些刚刚入行的小伙伴不清楚前端.后端.到底指的是什么?两者直接的区别 前端开发 前端开发主要涉及网站和App,用户能够从浏览器上或A ...

  8. 【nodejs原理&源码杂记(8)】Timer模块与基于二叉堆的定时器

    [摘要] timers模块部分源码和定时器原理 示例代码托管在:http://www.github.com/dashnowords/blogs 一.概述 Timer模块相关的逻辑较为复杂,不仅包含Ja ...

  9. IDEA插件开发(一)一个简单的表单demo

  10. Java修炼——文件夹的复制

    文件夹的复制用到了俩个流:缓冲流和文件字节流 缓冲流用来加快写入和读取速度. 在这里我简述一下复制文件夹的过程,当然复制文件夹都可以,复制文件更是不在话下 1.首先要明确俩点.要复制的文件夹的位置(源 ...