Skip to Content
Node for Front-End Developers
book

Node for Front-End Developers

by Garann Means
January 2012
Beginner
60 pages
1h 18m
English
O'Reilly Media, Inc.
Content preview from Node for Front-End Developers

Serving Client-Side Assets

Serving other client-side assets like CSS, images, and client-side JavaScript (of course) looks very similar to serving HTML. We’ll need to add some additional robustness to the code we’ve already built, but a few changes will allow us to provide resources to the client pretty easily. All we actually need to change is the way we set the Content-Type in our response, which means it’s necessary to modify the default header. This time, instead of changing the status code we’re returning, we’ll change that header property. We’ll cheat a little bit right now to make this more straightforward and assume that all URLs to resources will be relative to the root of our application.

The first change we’ll make is to store any directories in the requested URL, so that if our resources are organized into directories, we’ll still be able to use this same function to access them. We’ll remove the first character, since that should always be a slash, to make it easier down the line to find out whether or not the file we want is in a subdirectory:

  var filename = path.basename(req.url) || "index.html",
    ext = path.extname(filename),
    dir = path.dirname(req.url).substring(1),
    localPath = __dirname + "/public/";

The next thing we need to change is the section where we’re testing the file extension to make sure we can serve it. We could just test for a bunch of different extensions, but it’ll be easier to just create a hash of the extensions we want to support and the MIME types ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.

Read now

Unlock full access

More than 5,000 organizations count on O’Reilly

AirBnbBlueOriginElectronic ArtsHomeDepotNasdaqRakutenTata Consultancy Services

QuotationMarkO’Reilly covers everything we've got, with content to help us build a world-class technology community, upgrade the capabilities and competencies of our teams, and improve overall team performance as well as their engagement.
Julian F.
Head of Cybersecurity
QuotationMarkI wanted to learn C and C++, but it didn't click for me until I picked up an O'Reilly book. When I went on the O’Reilly platform, I was astonished to find all the books there, plus live events and sandboxes so you could play around with the technology.
Addison B.
Field Engineer
QuotationMarkI’ve been on the O’Reilly platform for more than eight years. I use a couple of learning platforms, but I'm on O'Reilly more than anybody else. When you're there, you start learning. I'm never disappointed.
Amir M.
Data Platform Tech Lead
QuotationMarkI'm always learning. So when I got on to O'Reilly, I was like a kid in a candy store. There are playlists. There are answers. There's on-demand training. It's worth its weight in gold, in terms of what it allows me to do.
Mark W.
Embedded Software Engineer

You might also like

Professional Website Performance: Optimizing the Front-End and Back-End

Professional Website Performance: Optimizing the Front-End and Back-End

Peter Smith
Your First Week With Node.js, 2nd Edition

Your First Week With Node.js, 2nd Edition

James Hibbard, Craig Buckler, Mark Brown, Nilson Jacques, James Kolce, Paul Orac, M. David Green, Florian Rappl
What Successful Project Managers Do

What Successful Project Managers Do

W. Scott Cameron, Jeffrey S. Russell, Edward J. Hoffman, Alexander Laufer

Publisher Resources

ISBN: 9781449329112Errata Page