问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

GitHub 及 GitHub Desktop 详细使用教程(通俗易懂)

创作时间:
作者:
@小白创作中心

GitHub 及 GitHub Desktop 详细使用教程(通俗易懂)

引用
CSDN
1.
https://blog.csdn.net/TYRA9/article/details/144791691

GitHub是一个全球知名的代码托管平台,它不仅用于存储和管理代码,还支持团队协作、项目管理和持续集成等功能。GitHub Desktop作为GitHub的图形化客户端,让开发者可以更直观地管理代码仓库,而无需使用复杂的命令行。本文将从GitHub的基本概念入手,详细介绍GitHub的功能和使用方法,并通过图文结合的方式,帮助读者快速掌握GitHub Desktop的使用技巧。

Δ前言

学习Git之前,很有必要先了解一下GitHubGitHub Desktop的使用教程。

  • 注意事项——
    1. 代码中的注释也很重要;
    2. 不要眼高手低,自己跟着过一遍才真正有收获;
    3. 点击文章的侧边栏目录或者文章开头的目录可以进行跳转。

一、GitHub教程

1.什么是GitHub?

GitHub是一个在线软件源代码托管服务平台,用于公开程序或软件的代码,并使用Git作为版本控制软件——From Wikipedia。说是代码托管平台,其实只要你想,各种类型的文件都可以上传到GitHub,并且可以决定它们是否被其他人可见;同样地,你也可以在GitHub上浏览和操作其他用户上传的文件(如果这些文件可见的话)。

2.仓库和对仓库的操作:

2.1 Repository(仓库)

GitHub以“仓库”为基本单位进行代码托管,一个仓库包含了该项目的所有文件、版本历史和协作信息。所有的文件都必须存放在仓库中,也就是说,不管你要在GitHub上存放什么东西,首先必须有一个地方去放这些东西,这个地方就是Repository(仓库)。

项目和仓库是一一对应的,但文件和仓库并不是一一对应的,一个项目会有许多文件,实现功能相同或相似的文件往往存放在同一个仓库,但毫无相关的不同文件也可以放在同一个仓库,亦或存放在不同的仓库,完全由业务需求来决定,很灵活。值得一提的是,不同的仓库均可设置为public(可见)或者private(不可见)两种状态,当你将你的一个仓库设置为public时,我们就称“你在GitHub上开源了一个项目”。

如果是刚刚创建GitHub账户,GitHub默认不会为你创建仓库,所以我们需要先创建一个仓库,才能向GitHub上传文件(上传到指定的仓库),其中“上传文件”这一操作,称为“PUSH”,可以理解为将文件推送到了仓库中,下文中up会进行创建仓库和推送文件的演示。

2.2 Fork(派生)

作为全球最大的代码托管平台,GitHub上开源的好项目自然是少不了(下文中up会演示如何找项目),有时候看来看去难免就眼馋(bushi,这时候你就可以“Fork”一个你喜欢的项目到你自己的账户中。一个项目的forks的数量在一定程度上可以反映出这个项目的火热程度。

Fork功能在GitHub上用于将别人开源的项目派生一个副本到你的账户。你可以自由地修改、实验和开发派生出来的仓库,而不会影响原始项目。Fork后的仓库独立存在,并且,你可以提交更改,并通过Pull Request请求将这些更改合并回原始仓库。

同样地,别人也可以Fork你开源的项目,这样他的GitHub主页上便会多出一个基于你的项目的项目,他可以在此基础上自由地修改、实验和开发这个项目,而不会对你原来的项目造成任何影响。 当然,如果后续你修改了原来的项目,那么他需要自己去做同步处理。

2.3 Star(收藏)

不同于知乎,B站,X等我们熟悉的社交媒体平台,GitHub上并没有提供“点赞”的功能,但是提供了“收藏”的功能,就是我们的“Star”。通过“Star”一个开源项目,你可以——

  1. 表达对该项目的喜爱或认可(这是收藏功能的应有之义)。
  2. 将项目添加到你的收藏列表,方便日后查找(这是我们平时在各大平台使用收藏功能的出发点和落脚点)。
  3. 帮助项目获得更多关注,因为加星数越多,项目的受欢迎程度就越高(这是收藏功能的本质要求)。

2.4 Watch(追番)

追番后,番剧有什么新的更新动态都会第一时间通知提醒你。同样地,如果你“Watch”了一个项目,那只要这个项目有任何更新,都会第一时间通知提醒你;比如别人提交了一个Pull Request,或者发出了Issue等等,你都会在通知中心接收到相关通知。

2.5 Issue(问题)

你能保证你开源的项目天衣无缝,完美无瑕,挑不出一点毛病吗?别扯了,是个项目就有优化的空间。别人也一样,偶尔开源的项目出点小猫小饼的都很正常。如果你在浏览别人的项目时发现一些小猫饼,并且你还没能力解决,或者别人开源的项目中有一些你看不懂的地方,你就可以通过在它的项目中“Submit new issue”(提交一个新的问题),接着等待管理者的解答。

同样地,别人如果发现了你代码中的小bug,或者其他一些做的不够好的地方,也可以向你提出一个Issue,然后你看到这些Issues后就可以去逐个解决、修复、更新和完善。总结,Issue类似于“留言”的功能

问题的发出者或者回答者其中一方可以选择Close issue(关闭问题),表示该问题已经🆗了。

2.6 Pull Request(引出请求)

“Pull Request”建立在“Fork”的基础上,它用于提交代码更改请求。它的作用是:

  1. 提交更改:当你在一个分支上完成修改后,可以通过Pull Request(简称PR)请求将这些更改合并到主分支
  2. 代码审查:团队成员可以查看、评论和讨论你的更改,确保代码质量。
  3. 协作:提供一个平台来讨论修改,解决冲突,并在合并前进行必要的调整。
  4. 记录历史:所有讨论和更改记录都保存在Pull Request中,方便日后查阅。

2.7 Projects(项目板)

Projects,即项目板,包括议题、拉取请求和注释,在选择的列中分类为卡片且不同列中的卡片可以重新排序。它的作用是——

  1. 帮助组织工作和排列工作的优先级。
  2. 灵活地创建适合需求的工作流程。

3.图文演示:

我这个演示默认你已经注册了一个GitHub账户,“注册”流程就不用我演示了吧,宝宝题(,这里up只提醒大家一点——注意选好邮箱(不推荐用QQ邮箱)。

首先我们在Repositories页面,选择“New”,以准备创建新仓库,如下图所示:

进入创建仓库的页面后,要注意一下几个信息:

特别说明,如果你想在GitHub上发布一个静态网页,仓库名必须命名为“username.github.io”,这是甲鱼的屁股——龟腚(规定)。

好,继续,确定一些细节选项,如下图所示:

刚刚创建后的仓库,除了README.md文件外一无所有(如果你在创建仓库时勾选了这个选项的话),这时候我们可以通过“Upload files”功能来上传文件,如下图所示:

"Upload files"界面如下:(可以将需要上传的文件拖到文件接收区)

注意,每一次提交的记录都将保存在Repository中,所以你需要为每次提交给出名字和说明,方便以后查看,如下图所示:

接着,点击Commit changes,完成“提交”的操作,即可看到“高等数学.xmind”已经出现在仓库中,如下所示:

另外,在Commits中,我们可以看到这次提交的具体说明,如下图所示:

下载后可以看到思维导图正常显示,如下:(备注:数学二)

4.怎么在GitHub上找项目:

4.1 根据项目名称的特点查找

在搜索框中,我们可以通过“in:name xxx”来轻松找到项目名中含有“xxx”字样的项目,比方说我要找一个SSM的项目,我就可以通过"in:name SSM"来查找,如下图所示:(PS: 类似的还有in:readme xxx,表示查找README.md文件中含有"xxx"字样的项目;以及in:description xxx,表示查找项目描述中含有"xxx"字样的项目)

可以看到,通过in:name SSM找到项目中,项目名都包含“SSM”。

4.2 根据项目的Star数据查找

上面我们仅仅根据仓库名查找,出来三万多条查找结果,我们当然想着要优中择优,而Star的数量和项目的质量成正相关。我们可以通过"stars:>number"来查找stars的数量超过number的仓库。如下所示:

可以看到,我们在仓库名包含"SSM"的基础上,搜索stars大于1000的仓库,三万多条记录直接变成了七条,可见star的数据在GitHub上的含金量。

4.3 根据项目的Fork数据查找

尽管stars大于1000已经是来之不易,但是我还要继续优中择优,希望在此基础上查找forsk大于800的仓库,可以通过"forks:>number"来查找forks的数量超过number的仓库。如下所示:

4.4 根据项目的最近更新时间查找

尽管stars大于1000且forsk大于800已经是来之不易,但是我还要继续优中择优,希望找到2024年仍然有过更新的项目。通过"pushed:>xxxx-xx-xx",可以查找到最近提交时间大于指定时间的项目。如下所示:

不是哥们,一个都没,SSM真的被时代抛弃了吗?😭(bushi

4.5 根据项目所使用的编程语言查找

通过"language:xxx"来查找编程语言为xxx的项目,如下所示:

PS :更多高级查找方式,见GitHub官方介绍——https://github.com/search/advanced

二、GitHub Desktop教程

1.什么是GitHub Desktop?

GitHub Desktop 是一个由 GitHub 开发的图形化界面应用程序,旨在简化 Git 和 GitHub 的使用。它为用户提供了一个直观的方式来管理代码仓库,而无需使用命令行。

2.利用GitHub Desktop创建新仓库:

同上文GitHub教程一样,up默认你已经下载好了GitHub Desktop,并且已经关联好了自己的GitHub账号(鼠标点点就完事儿了)。所以up就直接开始演示了。

通过File-->New repository...,可以在GitHub Desktop上创建新的仓库,如下图所示:

创建过程和在GitHub网站上基本一致,如下:

注意,这个时候如果我们去看自己的GitHub会发现根本没有“Leetcode-Buster”这个仓库,因为它只是创建在了本地,你还需要将他发布到GitHub,如下图所示:

发布后,再去GitHub网站上查看自己的仓库,会发现多了一个“Leetcode-Buster”,如下所示:

3.从GitHub网站上克隆已有的仓库:

在上文“GitHub--->图文演示”中,我们创建了一个“Mind-Map-Collection”仓库,但是这个仓库并不在本地,GitHub Desktop允许我们一键将仓库克隆到本地,如下所示:

选择**File-->Clone repository...**即可进行克隆,如下所示:

接着,我们便得到了克隆的仓库,包括该仓库详细的提交历史,如下图所示:

4.将本地仓库的修改PUSH到GitHub:

之前创建的“Mind-Map-Collection”仓库中目前只有“高等数学.xmind”一个文件,我们当然可以在GitHub上通过“Upload files”功能来上传文件,但这次我们试试用GitHub Desktop,先将新的文件Commit到本地仓库,再从本地仓库PUSH到GitHub上

现在up准备了“408提纲.xmind”这么一个思维导图,如下图所示:

现在up把这个文件,放到对应的本地仓库(即up刚刚才从GitHub上克隆过来的本地仓库),如下所示:

这时候,GitHub Desktop会立刻检测到仓库文件的变换,如下图所示:

接着,我们通过Commit提交到本地仓库,如下:

这还没玩,这只是本地仓库确认了“408提纲.xmind”这个新文件的加入,但是你还要把它PUSH到GitHub网站上,如下图所示:

PUSH之后,我们再去GitHub网站上访问“Mind-Map-Collection”仓库,就会发现多了“408提纲.xmind”文件,如下图所示:

Δ总结

  • 🆗,以上就是“GitHub 及 GitHub Desktop 详细使用教程”一文的全部内容了,感谢阅读!
  • 博文中呈现的内容其实只是GitHub的冰山一角,GitHub非常强大,也非常迷人,未来up也会把GitHub更多好用且好玩的地方分享给大家,并不断完善这篇博文。
  • 另外对于“GitHub Desktop”的使用演示,up也只是列举了一些最基本的使用,之后也会适时地更新一些其他功能的演示。
© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号