Document

NodeJS Setup With Express, HTML, CSS, JS & EJS

In this article, we will have a look at how to set up a NodeJS Server, we will cover Express, how to add CSS, JS and Images to your project and finally, we will look at how to use EJS. If you wish, you can also check out the video that I made.

Create a project folder

Name your project folder. This is where your project is going to live and all packages will be installed. Talking about packages, let’s go to step to and create our server setup.

Setup Server – Package.json file

This file is usually in the project root and it’s called package.json. It holds various metadata relevant to the project and it’s used to give information to npm that allows identifying the project as well as handle dependencies.

Go to the root of the folder, open PowerShell or the Terminal if you are using a mac and type the following command.

As long as you have nodejs installed, this should guide you through the setup of your project. Once you finish with the installation, open your package.json file and just double check to see if everything is looking good.

Now let’s install some dependencies.

Читайте также:  Cfg cheat css v34

Install Dependencies

The dependencies we need to install to get started are Express and EJS.

Express is a web application framework for Node.js that is designed for building web applications and API’s.

EJS is a simple templating language that lets you generate HTML markup with plain JavaScript. PUG is another good alternative that you can use.

So let’s install express and ejs together by running the following command:

Install Nodemon

Nodemon is a tool that helps develop node.js based applications by automatically restarting the node application when file changes in the directory are detected.

To install nodemon simply do:

npm install nodemon --save-dev

Project Structure

Now let’s create the following folders and files, leaving node_modules, readme.md, package-lock and package-json as that should have been automatically generated by now.

📂 node_modules 📂 public 📂 css 📜 main.css 📂 img 🖼 cat.jpg 📂 js 📜 script.js 📂 views 🌍 about.ejs 🌍 index.ejs 📜 README.md 🌍 app.js 📜 package-lock.json 📜 package-json

Run it

Before we run the project to see if everything is working as intended, we need to add some more metadata in our package.json file.

Open your package.json file and add the following under scripts

Your full json file should look something like this:

< "name": "Learning NodeJS", "version": "1.0.0", "description": "NodeJS Tutorial", "main": "index.js", "scripts": < "test": "echo \"Error: no test specified\" && exit 1", "start": "nodemon app.js" >, "author": "", "license": "ISC", "dependencies": < "ejs": "^3.1.3", "express": "^4.17.1" >, "devDependencies": < "nodemon": "^2.0.4" >>

Save the file and now you should be able to run your project by simply doing:

We are getting close, but there are a few more things that we need to do before we are able to see our project. First, we need to add ‘express’ and select port number that NodeJs can listen on. Let’s do that.

In your app.js folder add the following code below and then run the project with “npm start”:

// Imports const express = require('express') const app = express() const port = 5000 // Listen on Port 5000 app.listen(port, () => console.info(`App listening on port $`))

Run your app, and see what happens. In PowerShell or Terminal (for Mac) you should see a message:

App listening on port 5000unless the port is already taken, then you can change it to 3000 or something like that.

Static Files

This will allow us to easily access our statics files such as css, js and images from our root folder of the project. Let’s have a look at how we can do that:

// Static Files app.use(express.static('public')); // Example for other olders // app.use('/css', express.static(__dirname + 'public/css'))

Setting up our View’s & EJS

This does two things. It will help us set up our views folder, where our html files will live and also we need to set the view engine which in our case is the EJS.

// Set View's app.set('views', './views'); app.set('view engine', 'ejs');

Rendering Pages

In this example, I will give you two options. One rendering the index.ejs file and one that simply grabs the about.html file.

// Navigation app.get('', (req, res) => < res.render('index', < text: 'Hey' >) >) app.get('/about', (req, res) => < res.sendFile(__dirname + '/views/about.html') >)

Your final code for app.js should look something like this:

// Imports const express = require('express') const app = express() const port = 5000 // Static Files app.use(express.static('public')); // Specific folder example // app.use('/css', express.static(__dirname + 'public/css')) // app.use('/js', express.static(__dirname + 'public/js')) // app.use('/img', express.static(__dirname + 'public/images')) // Set View's app.set('views', './views'); app.set('view engine', 'ejs'); // Navigation app.get('', (req, res) => < res.render('index', < text: 'Hey' >) >) app.get('/about', (req, res) => < res.sendFile(__dirname + '/views/about.html') >) app.listen(port, () => console.info(`App listening on port $`))

Example of EJS page

For our index.html let’s see how we can add our stylesheet and also some EJS code.

       Index baby cat

Final

Run the project by doing npm start and then open “localhost:5000” in your browser. If you want to visit the about page you should add a slash after the URL just like this “localhost:5000/about”

Credit: Cat image Photo by Ramiz Dedaković on Unsplash

More Resources:

Author

Hi! I’m Raddy. I am a web developer, often making YouTube Videos, Blog Posts and side projects. Enquiries: hello@raddy.co.uk

Recreating the Battle.net UI using HTML & CSS (SCSS) for fun

You can include your js file in your HTML, in the head and start using it just like the styles (main.css)

Hey Raddy, I have watched you on your YouTube channel. That is nice. I have a problem whenever I show my static html page the css linked with it seems not to be css. When I open console and look the source i found there my css files; are converted into html.
Please help me.

Hey Mohd, Would you be able to send a screenshot so I can get a better understanding of what is going on.
You need to make sure that the about.ejs and index.ejs end with EJS. I messed it up on the article (it’s now updated). The other thing that you can do is to double-check the path to the CSS.

You can also download the code from GitHub and see if you have missed something. It could be a silly typo mistake.

Did you add the “background-repeat” property to your CSS? Could add your background image to your body and do something like this:

body background-image: url(«gorilla.gif»);
background-repeat: repeat;
>

Hi Raddy, I want build version. like: index.html
about.html “scripts”: “test”: “echo \”Error: no test specified\” && exit 1″,
“start”: “nodemon app.js”
“build”: “anythig”
>,

Hey Gurpal, I am not sure if I understand your comment. Could you expand on it please and I will try to help

I’ve actually never heard of it. They do have an installation guide here if this helps: https://docs.nodebb.org/installing/os/

Hi! Great article by the way! I would like to know if it is possible to connect multiple front-end pages (those that use only HTML+CSS+JS) to Node.js server, for instance:
– main website page (main.html)
– about page (about.html)
– log in / sign up page (form.html)
(plus CSS and JS files for all those pages)? I tried to split those files into three folders – main (main.html, main.css and main.js), about (about.html, about.css and about.js), form (form.html, form.css, form.js) and connect them to index.js file on my Node.js server, but it only displayed files in the first folder, while ignoring the others. I want to make it possible to navigate between pages in browser using “/“ (as in your article). How could I do that?

Hey Nick, I am glad that you like the article! You can do that in two steps. First define a static folder where you can easily access the HTML, CSS, JS. To keep it organised call it ‘views’.
Inside your views, you will have your main, about & login folders. In app.js set the public folder of views
app.use(express.static(‘views’)); Now create your routes so you can visit by doing / for homepage and /about.
app.get(«/», (req, res) => res.sendFile(__dirname + «/views/main/main.html»);
>); app.get(«/about», (req, res) => res.sendFile(__dirname + «/views/about/about.html»);
>);
Then for your HTML, you can link your CSS / JS like this (it won’t let me post HTML) soo:

In your HTML head tag: href=»/main/main.css»

Note that you no longer have to specify ‘views’. Just put the folder where you want to grab the JS / CSS.
The main problem that you will have is that you won’t be able to pass data to the HTML. This is why is best to use a templating engine like EJS, Handlebars or Pug. There are many options…
Your other option is to separate your Front end from your back end. You can use NodeJs as an API and then fetch the data using JS in your HTML.

Hey Raddy, Article is Awesome!
Its very helpful for me, really appreciate you.
Keep sharing you experience for NodeJS Development & Solutions, Thanks You

Источник

Node.js: как встроить Node.js в HTML?

Обратите внимание: я хочу узнать node.js , поэтому явные и другие библиотеки и модули не отвечают за меня, потому что я хочу знать логику процесса.

Этот вопрос не относится к программированию встроенных систем, поэтому я удалил тег. см. stackoverflow.com/tags/embedded/info

4 ответа

Что вы описываете/запрашиваете препроцессор node.js. Он существует, но считается вредным.

Лучшим решением будет использование представлений, используемых в express. Взгляните на screencasts.

Если вы должны делать все с нуля, вы можете написать механизм для микро-шаблонов.

function render(_view, data) < var view = render.views[view]; for (var key in data) < var value = dataNode js in html page; view.replace(">", value); > return view; > render.views = < "someView": "

>

" >; http.createServer(function(req, res) < res.end(render("someView", < "foo": "bar" >)); >);

Есть веские причины, по которым плохое смешивание кода php/asp/js напрямую с HTML. Это не способствует разделению проблем и приводит к коду спагетти. В наши дни стандартным методом являются шаблоны для двигателей, подобные описанным выше.

Хотите узнать больше о микро шаблонах? Прочтите статью Дж. Ресига.

Здравствуйте, @Raynos Не могли бы вы объяснить, как я могу выполнить команду node.js из файла .html с помощью этого механизма шаблонов? Как я понимаю, это просто меняет foo на bar? или я опять что то не так понял?

@CIRK использует больший шаблонизатор. Усы, EJS, Jade, JQuery Templ и т. Д. Посмотрите на экспресс-скринкасты и пока вы используете экспресс, у него отличный движок просмотра

Привет. 2 из 3 ссылок не работают. Я не знаю, могут ли они быть исправлены, но я хотел бы получить доступ к этим материалам 🙂

Вы можете попробовать использовать JooDee, веб-сервер node, который позволяет встраивать JavaScript-серверы на ваши веб-страницы. Если вы знакомы с node и PHP/ASP, вам просто нужно создавать страницы. Вот пример того, как выглядит страница ниже:

Использование JooDee также позволяет вам без особого труда выставлять серверные javascript vars клиенту, добавляя атрибуты к стороне сервера объектов «Клиент» и обращаясь к сгенерированному объекту «Клиент» на JavaScript-стороне вашего клиента.

не используйте это. Это было написано моим другом в колледже, прежде чем мы поняли зло того, что мы делали!

Используйте механизм шаблона. От терминала

var ejs = require('ejs'); var options = < locals: < foo: function() < return "bar"; >> >; var template = " 

"; console.log(ejs.render(template, options));

Источник

Оцените статью