Part 3. Debugging JavaScript
warning
This feature is only supported in the Professional edition. This edition is commercial, and it provides an outstanding set of features: refer to the comparison matrix for more details.
The possibility to debug JavaScript is vital for web developers. With IntelliJ IDEA-based products, such debugging becomes quite easy. To illustrate the JavaScript debugging capabilities with PyCharm, we’ll create a very basic script that just shows some numbers in a browser page, and then debug it on a server.
In case of debugging on an external web server, the application files are deployed on it, and you have their copies on your computer. No matter, whether the web server itself is running on a physically remote host or on your machine, application files deployed on it are treated as remote.
When a remote HTML file that loads some JavaScript is opened, the debugger tells PyCharm the name of the currently processed file and the number of the line to be processed. PyCharm opens the local copy of this file and indicates the line with the provided number. This behaviour is enabled by specifying correspondence between files and folders on the server and their local copies. This correspondence is called mapping, it is set in the debug configuration.
Make sure that:
You are working with PyCharm Professional Edition version 3.0 or later.
You are working with Google Chrome.
You are using XAMPP as an application server.
tip
Chrome can't have its console window open.
This tutorial is created with the following tools:
PyCharm Professional 2017.1.
Google Chrome.
On the main menu, choose File | New Project, and do the following:
choose the Pure Python project type
specify the project location C:
\SampleProjects \py \MyJSProject choose the Python interpreter
data:image/s3,"s3://crabby-images/fb2f9/fb2f9380f0b4609e30cad9479a2ee9c0d835a127" alt="Create a new project Create a new project"
When ready, click Create.
Choose to open this new project in a separate window, not adding it to any of the currently open projects:
data:image/s3,"s3://crabby-images/e3ac7/e3ac7cbcef1da7cd58fa4f8aea0744a5bb3b8a93" alt="Open a project Open a project"
First, let’s create a HTML page. To do that, with the Project tool window having the focus, press AltInsert, choose HTML file on the popup menu, and enter the filename numbers
.
PyCharm stubs out an HTML file with some initial contents. Next, embed a reference to a JavaScript file into this HTML file. To do that, type the following code inside the <body> tags:
<script type="text/javascript" src="numbers.js" language="JavaScript"></script>
Mind the code completion, which is available while you type:
data:image/s3,"s3://crabby-images/20d90/20d9035c3c74f89efcc6a6de0eed33228408a7e3" alt="Code completion Code completion"
When ready, pay attention to the highlighted filename numbers.js. This is a reference to a non-existent JavaScript file. Place the caret at this name and press AltEnter (or click the yellow light bulb ); a quick-fix is suggested – create the missing file:
data:image/s3,"s3://crabby-images/45ee5/45ee56a747d5a9719f541a06c1c0fc8ceec6333a" alt="Intention Action Intention Action"
Choose this quick-fix, and have the stub JavaScript file ready. Next, enter the following code:
var i=0;
for (i=0;i<=10;i++)
{if (i==3)
{
continue;
}
document.write("The number is " + i);
document.write("<br/>");
}
Now let’s set breakpoints to our JavaScript file. This is most easy – just click the left gutter at the line you want the script to suspend:
data:image/s3,"s3://crabby-images/3b59e/3b59e34f1652ecc7384be07e6470a970aa4447c4" alt="Breakpoint set Breakpoint set"
To create a server, follow these steps:
Open the Settings dialog (press CtrlAlt0S or click
on the main toolbar)
Expand the node Build, Execution, Deployment, and click the page Deployment.
On the Deployment page, click
.
Specify the server name
MyRemoteServer
and typelocal or mounted server
.
Then, configure the server. In the Connection tab, specify the directory where your local files will be uploaded; in our case, this directory is C:
data:image/s3,"s3://crabby-images/472c8/472c83d53ca8b94d17752bfff319646c04dcf79d" alt="Configure connection to the server Configure connection to the server"
Next, click the Mappings tab. Here define the local path, the deployment path on the server (which is relative to the folder specified in the Connection tab), and the Web path on the server:
data:image/s3,"s3://crabby-images/0829a/0829a68c4e5a465c8bfcdd327f4ffaba6a0b5763" alt="Configure folder mappings Configure folder mappings"
Make the server the project default. To do that, click button in the Deployment toolbar.
data:image/s3,"s3://crabby-images/8bce3/8bce3a20b797fe352f4c0b99c6b5421d78b1c12c" alt="Set a server as default Set a server as default"
Click OK to apply changes are close the Settings dialog.
Finally, copy your project C:
Let's make sure the server is up and running, and, which is even more important, visible to PyCharm. To do that, on the main menu, choose Tools | Deployment | Browse Remote Hosts. The Remote Hosts tool window shows the newly created server:
data:image/s3,"s3://crabby-images/5b9b9/5b9b9a9a31129390d55dd1d6fed35e1f1d2aa8b2" alt="Browse remote server Browse remote server"
With PyCharm, it's just a snap... For example, you can easily do that via the main menu: choose Tools | Deployment | Upload to MyRemoteServer, or use the context menu:
data:image/s3,"s3://crabby-images/613d8/613d899ac984150e8724a89c9b73c31fe0d0ff5a" alt="Upload files to a remote server Upload files to a remote server"
The upload result is shown below:
data:image/s3,"s3://crabby-images/7fe7b/7fe7bfbae7a49436d43b93d62a794072156d63b4" alt="Upload results Upload results"
All the preliminary steps are done, and it’s time to proceed to the debugging session. To start it, right-click the background of the file numbers.html, and choose Debug 'number.html' from the context menu - thus you will launch the debugger with the default temporary run/debug configuration:
data:image/s3,"s3://crabby-images/dc846/dc8468d672727f3c228152f276c6a4a930319777" alt="Start debugging Start debugging"
When the debugging session is launched, your HTML page appears in the browser, and the Debug tool window opens. Your program execution suspends when the first breakpoint is hit. Such a breakpoint is marked with a blue stripe:
data:image/s3,"s3://crabby-images/b18af/b18afd12c1d4f3534310add6bbcaaba036bdc374" alt="Breakpoint hit Breakpoint hit"
As you step through your application, the corresponding information appears in the Debug tool window, and in the page of your web browser:
data:image/s3,"s3://crabby-images/20807/208078e1a0a9a1606c4f849a67a38fb62545d63e" alt="Web page paused in debugger Web page paused in debugger"
To step though the script, click or
; to terminate the debugger session, close the yellow banner, or click Cancel.
This tutorial is over. You've refreshed your knowledge about the following issues:
Created a server, configured its connection and mapping.
Deployed a file to the server.
Added breakpoints to your JavaScript code.
Started the debug session and examined the debugger information.
Thanks for your feedback!