5

I'm still new to javascript and node.js and was trying to accomplish something but I am encountering the error ReferenceError: Document not defined

Given the following code in seperate files:

Index.html:

<!DOCTYPE html>
<html>
<head>
    <title>My Test Website</title>
    <script type="text/javascript" src="script.js"></script>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    <p id="para1"> Some text here</p>
</body>
</html>

And script.js:

function getParagraphContents() {
    var paragraph = document.getElementById("para1");
    var temp = paragraph.textContent;
    console.log(temp);
}

So my problem being is I wanted to be able to run the command node script.js from the command line but keep getting an error message. I keep reading other answers and documentation but nothing seems to be the right answer. Any suggestions? P.S. I am using terminal on mac osx and have node and npm install correctly.

Thank you.

unChartedZone
  • 53
  • 1
  • 1
  • 5
  • Why do you need that ? – Ismail RBOUH Aug 03 '16 at 16:26
  • 1
    You can't run that clientside script in Node.js, that's not how it works, that script is for the browser, not the server. – adeneo Aug 03 '16 at 16:27
  • `script.js` is designed to run in a browser and to operate on the current page's HTML. Running `node script.js` does not really make any sense. While you can find libraries that will load an HTML document into node and give you a DOM representation of them that you can then run some browser-like scripts on, that isn't what you're attempting here as there is no document associated with `script.js` at all. It's just a script by itself. So running `node script.js` is like half an app. You need to explain what you're trying to accomplish from node. – jfriend00 Aug 03 '16 at 16:46

1 Answers1

7

script.js is a script designed to run in a browser, not in node.js. It is designed to operate on the current web page and uses the document object to get access to that page.

A node.js execution environment is not the same as a browser. For example, there is no notion of the "current page" like there is in a browser and thus there is no global document or window object either like there is in a browser.

So, this all explains why trying to run node script.js doesn't work. There's no global document object so your script quickly generates an error and exits.


We can't really tell from your question if you just don't really understand the difference between running scripts in a browser vs. running scripts in a node.js environment and that's all you need to have explained or if you actually want to operate on an HTML document from within node.js?

It is possible to operate on HTML pages from within node.js. The usual way to do that is to get an HTML parsing library like jsdom. You can then load some HTML page using that library and it will create a simulated browser DOM and will make things like the document object available to you so you could execute a browser-like script on an HTML document.

jfriend00
  • 683,504
  • 96
  • 985
  • 979
  • Thank jfriend00, that clears things up for me and will definitely checkout jsdom. I just wasn't sure what node js was really. I understand how scripts work in a browser but not sure how they work in node so I will look into that too. – unChartedZone Aug 03 '16 at 17:32