In software, the code you use is rarely self-contained. We often rely on packages that are created by other people. Often, these packages are git repositories themselves living on some provider like Github or GitLab.
Thus, it becomes necessary to ensure that their version control does not interfere with your existing codebase. This is where git submodules come in.