Search code examples
javascriptnode.jsnpmatom-editordomparser

dom-parser throwing syntax error even after installed from NPM


I am a beginner in this tech. please guide. Installed dom-parser from NPM package. and then when i declared below it is throwing syntax error. i know it is a very small things but i am puzzled and do not understand where i am going wrong. Already executed npm install dom-parser.

code like:

    const DOMParser = require('dom-parser'); 
    var domParser = new DOMParser();​​

error message below: var domParser = new DOMParser();​​

    SyntaxError: Invalid or unexpected token
        at wrapSafe (internal/modules/cjs/loader.js:1054:16)
        at Module._compile (internal/modules/cjs/loader.js:1102:27)
        at Object.Module._extensions..js 
        (internal/modules/cjs/loader.js:1158:10)
        at Module.load (internal/modules/cjs/loader.js:986:32)
        at Function.Module._load (internal/modules/cjs/loader.js:879:14)
        at Function.executeUserEntryPoint [as runMain] 
        (internal/modules/run_main.js:71:12)
        at internal/main/run_main_module.js:17:47
        [nodemon] app crashed - waiting for file changes before starting...

Thanks, Jowar

as requested by experts, code snippet below:

app.js file:

    const express = require("express");
    const bodyParser = require("body-parser");
const https = require("https");
const DOMParser = require('dom-parser');
const app = express();
app.use(bodyParser.urlencoded({
  extended: true
}));


app.get("/", function(req, res) {

  res.sendFile(__dirname + "/index.html");
});

app.post("/", function(req, res) {


  const url = "https://en.wikipedia.org/w/api.php?format=json&action=parse&page=Anthony%20Martial";

  https.get(url, function(response) {

    https.get(url, (resp) => {
      let data = '';

      // A chunk of data has been recieved.
      resp.on('data', (chunk) => {
        data += chunk;
      });

      // The whole response has been received. Print out the result.
      resp.on('end', () => {
        const jsonDATA = JSON.parse(data).parse;
        var jsonText = jsonDATA.text;
        var jsonTitle = jsonDATA.title;
        var jsonPageid = jsonDATA.pageid

        var str = JSON.stringify(jsonText);


        var domParser = new DOMParser();​​



        res.write("<p>player title is " + jsonTitle + " degree C</p>");
        res.write("<p>The pageid is " + jsonPageid + "</p>");
        res.write("<p>The pagetext is is " + str + "</p>");
        res.send();

      });
    });
  });
});



app.listen(3000, function(req, res) {
  console.log("server is running in port 3000");
});

index.html file: remember input field of index.html do not have any connaction with js file. this are just for test purpose.

    <!DOCTYPE html>
<html lang="en" dir="ltr">

<head>
  <meta charset="utf-8">
  <title>weatehr App API</title>

  <!-- <script src="app.js" charset="utf-8"></script> -->

  <link rel="stylesheet" href="css/style1.css">
  <link rel="stylesheet" href="css/style2.css">
</head>

<body>

  <form action="/" method="post">
    <label for="cityInput">City Name:</label>
    <input id="cityInput" type="text" name="cityName">
    <button type="submit"> Go </button>
    <h3>hello</h3>
  </form>

  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>


 <script src="https://code.jquery.com/jquery-3.5.1.slim.min.js" integrity="sha384-DfXdz2htPH0lsSSs5nCTpuj/zy4C+OGpamoFVy38MVBnE+IbbVYUew+OrCXaRkfj" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/umd/popper.min.js" integrity="sha384-Q6E9RHvbIyZFJoft+2mJbHaEWldlvI9IOYy5n3zV9zzTtmI3UksdQRVvoxMfooAo"    crossorigin="anonymous"></script>
  <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/js/bootstrap.min.js" integrity="sha384-OgVRvuATP1z7JjHLkuOU7Xw704+h835Lr+6QL9UvYjZE3Ipu6Tp75j7Bh/kR0JKI"  crossorigin="anonymous"></script>
  <script src="app.js" charset="utf-8"></script>
</body>

</html>

JSon file: installed pakage.

{
  "name": "callwikiapi-2",
  "version": "1.0.0",
  "description": "",
  "main": "app.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "body-parser": "^1.19.0",
    "dom-parser": "^0.1.6",
    "express": "^4.17.1"
  }
}

same error using codesandbox also. please heko , where i am going wrong. is there any dependent pakage which i have to install?

PFA codesandbox attached.codesandbox error


Solution

  • Issur resolved using jsdom.

        const jsdom = require("jsdom");
        const { JSDOM } = jsdom;
        const dom = new JSDOM("<!DOCTYPE html><p>Hello world</p>", { runScripts: "dangerously" });
    
        console.log(dom.window.document.querySelector("p").textContent);
    

    Thanks experts for all of your time.