-
Notifications
You must be signed in to change notification settings - Fork 22.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update code editors and dealing with files #37484
base: main
Are you sure you want to change the base?
Conversation
Preview URLs
Flaws (753)URL:
URL:
URL:
External URLs (18)URL:
URL:
URL:
|
@@ -36,29 +33,161 @@ Previously, we told you to install a code editor, as you'll need one to work thr | |||
|
|||
## What code editors are available? | |||
|
|||
Binary file editors like Microsoft Word are unsuitable for editing code. You need something that cleanly handles and outputs plain text. | |||
Before starting to code, you've probably already had some experience of working on text documents, probably in a program like Microsoft Word. You are probably also wondering whether you can work with code documents in these same programs? Unfortunately, the answer is "no": |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Before starting to code, you've probably already had some experience of working on text documents, probably in a program like Microsoft Word. You are probably also wondering whether you can work with code documents in these same programs? Unfortunately, the answer is "no": | |
Before starting to code, you may have had some experience working on text documents in a program like Microsoft Word. You might also be wondering whether you can work with code in these same programs. Unfortunately, the answer is "not really": |
Integrated Development Environments (IDEs) such as Visual Studio (Windows, not free), NetBeans (multiplatform, free), and WebStorm (multiplatform, not free) tend to have more features than simple code editors but tend to be more complex than what you need at this stage in your learning journey. | ||
You are better off with a fully-fledged code editor like [Visual Studio Code](https://code.visualstudio.com/) (multiplatform, free), [Sublime Text](https://www.sublimetext.com/) (multiplatform, not free), or [Notepad++](https://notepad-plus-plus.org/) (Windows, free). | ||
|
||
We would recommend Visual Studio Code (VS Code), as it is the editor we mostly use. If you do not already have VS Code (or another code editor) installed, [install it now](https://code.visualstudio.com/). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
minor suggestion
We would recommend Visual Studio Code (VS Code), as it is the editor we mostly use. If you do not already have VS Code (or another code editor) installed, [install it now](https://code.visualstudio.com/). | |
We would recommend Visual Studio Code (VS Code), as it is the editor we mostly use. If you do not already have VS Code (or another code editor) installed, you should [install it before proceeding](https://code.visualstudio.com/). |
In this section, we'll look at some of the most significant functionality that you will find in code editors, describing how they can help you with your coding work. | ||
|
||
> [!NOTE] | ||
> The sections below barely scratch the surface of what a code editor can do. For a more complete feature list, see the [Visual Studio Code documentation](https://code.visualstudio.com/docs) (or search the web for your chosen code editor's docs if you are using something different). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
> The sections below barely scratch the surface of what a code editor can do. For a more complete feature list, see the [Visual Studio Code documentation](https://code.visualstudio.com/docs) (or search the web for your chosen code editor's docs if you are using something different). | |
> The sections below only scratch the surface of what a code editor can do. For a more complete feature list, see the [Visual Studio Code documentation](https://code.visualstudio.com/docs) (or search the web for your chosen code editor's documentation if you are using something different). |
### Opening and editing files | ||
|
||
This may seem like an obvious point, but installing a code editor is useful because it will give you a single app that will open all code files you may want to use through your development work. There is nothing more annoying than double-clicking a file on your computer and having it open in a weird random app, or having your operating system tell you it doesn't recognize that file. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
:)
This may seem like an obvious point, but installing a code editor is useful because it will give you a single app that will open all code files you may want to use through your development work. There is nothing more annoying than double-clicking a file on your computer and having it open in a weird random app, or having your operating system tell you it doesn't recognize that file. | |
This may seem like an obvious point, but installing a code editor is useful because it will give you a single app that will open all code files you may want to use through your development work. There is nothing more annoying than double-clicking a file on your computer and having it open in a random, unrelated app, or having your operating system tell you it doesn't recognize that file. |
@@ -87,7 +87,7 @@ The terminal is available on macOS at `Applications/Utilities/Terminal`. | |||
|
|||
As with some other programming tools, using the terminal (or command line) on Windows has traditionally not been as simple or easy as on other operating systems. But things are getting better. | |||
|
|||
Windows has traditionally had its own terminal-like program called `cmd` ("the command prompt") for a long time, but this definitely doesn't have parity with Unix commands, and is equivalent to the old-style Windows DOS prompt. | |||
Windows has traditionally had its own terminal-like program called `cmd` ("the command prompt") for a long time, but this doesn't have parity with Unix commands, and is equivalent to the old-style Windows DOS prompt. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Leaving a TODO comment here checking if we mention https://learn.microsoft.com/en-us/windows/wsl/install
|
||
### Opening a project folder and creating files in VS Code | ||
|
||
While you can create text files inside the OS file system UI, it is generally easier and less error-prone to create them inside your code editor. In fact, VS Code has its own file explorer that allows you to create all the folders and files you need for your web projects. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we mention anything here about being careful not to edit things on your system in dangerous places? Like make sure you're editing or doing search/replace in the correct directory and not overwriting anything important (work in ~/code/projects
place or something?)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You already mention something down below, just worth considering if you think it might avoid some trouble.
|
||
## What structure should a website have? | ||
|
||
Next, let's look at what structures websites generally have. The most common things we'll have on any website project we create are an index HTML file and folders to contain images, style files, and script files: | ||
When you are working on websites locally on your computer, you should keep all the related files for each site in a single folder. In turn, you should keep all your website folders in one central folder, so they are all easy to find. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When you are working on websites locally on your computer, you should keep all the related files for each site in a single folder. In turn, you should keep all your website folders in one central folder, so they are all easy to find. | |
When you are working on websites locally (on your computer), you should keep all the related files for each site in a single folder. In turn, you should keep all your website folders in one central folder, so they are all easy to find. |
1. Many computer systems, including most web servers, are case-sensitive. So for example, if you put an image on your website at `test-site/images/MyImage.jpg` and then in a different file you try to reference the image with `test-site/images/myimage.jpg`, it may not work. | ||
2. When you invoke commands on the command line, you have to put quotes around file names with spaces in them, otherwise they will be interpreted as two separate items. | ||
3. Some programming languages (for example, Python) do not work well with spaces in file names in certain circumstances (for example, if these files are modules to be imported). | ||
4. File names commonly map to web addresses/URLs. If you, for example, have a file called `my file.html` in your server's root folder, generally it will be accessible at a URL like `https://example.com/my%20file.html`. Web servers usually replace the spaces in filenames with `%20` (the character code for spaces in URLs), which can create subtle bugs with some systems if they assume that file names and URLs match perfectly. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it's probably okay to introduce this term for the brave:
4. File names commonly map to web addresses/URLs. If you, for example, have a file called `my file.html` in your server's root folder, generally it will be accessible at a URL like `https://example.com/my%20file.html`. Web servers usually replace the spaces in filenames with `%20` (the character code for spaces in URLs), which can create subtle bugs with some systems if they assume that file names and URLs match perfectly. | |
4. File names commonly map to web addresses/URLs. If you, for example, have a file called `my file.html` in your server's root folder, generally it will be accessible at a URL like `https://example.com/my%20file.html`. Web servers usually replace the spaces in filenames with `%20` (because URLs are {{Glossary("Percent-encoding", "percent-encoded")}}), which can create subtle bugs with some systems if they assume that file names and URLs match perfectly. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, Chris! Leaving a +1, some comments for you, nothing major!
Description
When we restructured the MDN Learn web development section, some articles were published incomplete, with TODO sections.
This PR fills in content for Code editors, Dealing with files, and to a certain degree, Command line crash course.
The second and third ones weren't marked as incomplete, but the former really needed some updates, and the latter needed a few tweaks for consistency.
Motivation
Additional details
Related issues and pull requests