跳至主要内容

为项目贡献代码

了解如何通过 Fork 为项目贡献代码。

平台导航

关于 Fork

如果您想为其他人的项目做出贡献,但没有该仓库的写入权限,则可以使用“Fork 和 Pull Request”工作流。

分支是一个新的代码仓库,它与原始的“上游”代码仓库共享代码和可见性设置。分支通常用于在将想法或更改提议回上游代码仓库之前进行迭代,例如在开源项目中或用户无权访问上游代码仓库时。

您可以通过从您的分支向源代码仓库提交拉取请求来做出贡献。有关更多信息,请参阅“创建代码仓库分支”。

创建代码仓库分支

本教程使用Spoon-Knife 项目,这是一个托管在 GitHub 上的测试代码仓库,可让您测试分支和拉取请求工作流程。

  1. 导航到位于https://github.com/octocat/Spoon-KnifeSpoon-Knife项目。

  2. 在页面右上角,点击**创建分支**。

    Screenshot of the main page of repository. A button, labeled with a fork icon and "Fork 59.3k," is outlined in dark orange.

  3. 在“拥有者”下,选择下拉菜单并点击分支代码仓库的拥有者。

    注意

    如果您的用户名呈灰色,则表示分支已存在。相反,您应该更新现有的分支。有关更多信息,请参阅“同步分支”。

  4. 默认情况下,分支的名称与其上游代码仓库相同。或者,为了进一步区分您的分支,可以在“代码仓库名称”字段中输入名称。

  5. 或者,在“描述”字段中,输入分支的描述。

  6. 或者,选择**仅复制 DEFAULT 分支**。

    对于许多分支场景,例如为开源项目做出贡献,您只需要复制默认分支。如果您不选择此选项,则所有分支都将复制到新分支中。

  7. 点击**创建分支**。

注意

如果您想从上游代码仓库复制其他分支,可以从**分支**页面进行操作。有关更多信息,请参阅“在代码仓库中创建和删除分支”。

克隆分支

您已成功创建了 Spoon-Knife 代码仓库的分支,但到目前为止,它仅存在于 GitHub 上。要能够处理该项目,您需要将其克隆到您的计算机上。

您可以使用命令行、GitHub CLI 或 GitHub Desktop 克隆您的分支。

  1. 在 GitHub 上,导航到 Spoon-Knife 代码仓库的**您的分支**。

  2. 在文件列表上方,点击 代码.

    Screenshot of the list of files on the landing page of a repository. The "Code" button is highlighted with a dark orange outline.

  3. 复制代码仓库的 URL。

    • 要使用 HTTPS 克隆代码仓库,请在“HTTPS”下点击.

    • 要使用 SSH 密钥(包括组织的 SSH 证书颁发机构颁发的证书)克隆代码仓库,请点击**SSH**,然后点击.

    • 要使用 GitHub CLI 克隆代码仓库,请点击**GitHub CLI**,然后点击.

      Screenshot of the "Code" dropdown menu. To the right of the HTTPS URL for the repository, a copy icon is outlined in dark orange.

  4. 打开终端终端Git Bash

  5. 将当前工作目录更改为您想要克隆目录的位置。

  6. 键入git clone,然后粘贴您之前复制的 URL。它将如下所示,其中使用您的 GitHub 用户名代替YOUR-USERNAME

    git clone https://github.com/YOUR-USERNAME/Spoon-Knife
    
  7. 按**Enter**键。将创建您的本地克隆。

    $ git clone https://github.com/YOUR-USERNAME/Spoon-Knife
    > Cloning into `Spoon-Knife`...
    > remote: Counting objects: 10, done.
    > remote: Compressing objects: 100% (8/8), done.
    > remove: Total 10 (delta 1), reused 10 (delta 1)
    > Unpacking objects: 100% (10/10), done.
    

要了解有关 GitHub CLI 的更多信息,请参阅“关于 GitHub CLI”。

要创建分支的克隆,请使用--clone标志。

gh repo fork REPOSITORY --clone=true
  1. 在**文件**菜单中,点击**克隆代码仓库**。

    Screenshot of the menu bar on a Mac. The "File" dropdown menu is expanded, and the "Clone Repository" option is highlighted with an orange outline.

    Screenshot of the "GitHub Desktop" menu bar on Windows. The "File" dropdown menu is expanded, and the "Clone Repository" option is highlighted with an orange outline.

  2. 点击与您要克隆的代码仓库位置相对应的选项卡。您也可以点击**URL**手动输入代码仓库位置。

    Screenshot of the "Clone a repository" window. At the top of the window, tabs labeled "GitHub.com", "GitHub Enterprise" and "URL" are highlighted with an orange outline.

  3. 从代码仓库列表中,点击您要克隆的代码仓库。

    Screenshot of the "Clone a repository" window. The "github/docs" repository is highlighted with an orange outline.

  4. 要选择要将代码仓库克隆到的本地目录,请在“本地路径”字段旁边,点击**选择...**并导航到该目录。

    Screenshot of the "Clone a repository" window. A button, labeled "Choose", is highlighted with an orange outline.

  5. 在“克隆代码仓库”窗口底部,点击**克隆**。

创建用于工作的分支

在对项目进行更改之前,您应该创建一个新分支并检出该分支。通过将更改保存在其自己的分支中,您可以遵循 GitHub 工作流并确保将来更容易再次为同一项目做出贡献。有关更多信息,请参阅“GitHub 工作流”。

git branch BRANCH-NAME
git checkout BRANCH-NAME
git branch BRANCH-NAME
git checkout BRANCH-NAME

有关如何在 GitHub Desktop 中创建和管理分支的更多信息,请参阅“在 GitHub Desktop 中管理分支”。

进行和推送更改

继续使用您喜欢的文本编辑器(如Visual Studio Code)对项目进行一些更改。例如,您可以更改index.html中的文本以添加您的 GitHub 用户名。

准备好提交更改后,暂存并提交更改。git add .告诉 Git 您希望在下次提交中包含所有更改。git commit会对这些更改进行快照。

git add .
git commit -m "a short description of the change"
git add .
git commit -m "a short description of the change"

有关如何在 GitHub Desktop 中暂存和提交更改的更多信息,请参阅“在 GitHub Desktop 中提交和查看项目更改”。

当您暂存和提交文件时,您实际上是在告诉 Git:“好的,对我的更改进行快照!”您可以继续进行更多更改,并进行更多提交快照。

目前,您的更改仅存在于本地。准备好将更改推送到 GitHub 后,请将更改推送到远程。

git push
git push

有关如何在 GitHub Desktop 中推送更改的更多信息,请参阅“从 GitHub Desktop 推送更改到 GitHub”。

创建拉取请求

最后,您已准备好将更改提议到主项目中!这是生成他人项目的代码分支的最后一步,并且可以说是最重要的一步。如果您做出了您认为对整个社区都有益的更改,那么您绝对应该考虑回馈。

为此,请转到 GitHub 上的代码仓库,您的项目位于该代码仓库中。对于此示例,它位于https://github.com/<your_username>/Spoon-Knife。您会看到一个横幅,指示您的分支比octocat:main领先一个提交。点击**贡献**,然后点击**打开拉取请求**。

GitHub 将带您到一个页面,该页面显示您的分支与octocat/Spoon-Knife代码仓库之间的差异。点击**创建拉取请求**。

GitHub 将带您到一个页面,您可以在其中输入更改的标题和描述。提供尽可能多的有用信息以及您首先创建此拉取请求的原因非常重要。项目所有者需要能够确定您的更改是否像您认为的那样对每个人都有用。最后,点击**创建拉取请求**。

管理反馈

拉取请求是讨论的场所。如果项目所有者拒绝您的拉取请求或要求提供更多有关创建原因的信息,请不要感到冒犯。即使项目所有者选择不合并您的拉取请求,您的更改仍存在于您的分支中。可能是其他人会发现您的分支比原始项目更有价值。

查找项目

您已成功创建分支并回馈到代码仓库。继续前进,做出更多贡献!有关更多信息,请参阅“查找在 GitHub 上为开源做出贡献的方法”。