Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

django npm and node packages architecture

On the project I am joining this is the architecture for the node_packages:

|- Django project |-- app1 |-- app2 |-- node_modules |--- foundation-sites |--- grunt |-- static |--- css |--- images |--- js |--urls.py |--settings.py |--package.json 

I personally think node_packages should be in the static under the js folder as well as the package.json like so:

|- Django project |-- app1 |-- app2 |-- static |--- css |--- images |--- js |---- node_modules |----- foundation-sites |----- grunt |---- packages.json |--urls.py |--settings.py 

is there a difference? which is best practice? why?

like image 721
elad silver Avatar asked Jan 31 '17 19:01

elad silver


People also ask

Does Django use NPM?

Setting Up JavascriptYou can also now use npm packages in your django app. For example, if you wanted to use jQuery simply install it. And import it in your script. js file.

Can we use node JS and Django together?

You can't merge them. You can send messages from Django to Node. Js through some queue system like Reddis.

How many node packages are there?

How many node packages are there? There are 350,000 node packages. NPM registry contains the most populated package registry. This is a fact that it is considered to be the largest package registry in the world.


1 Answers

I understand your thinking of wanting to keep all the javascript related files in one place, but here are a couple of reasons you might want to keep the node_modules folder and the package.json file out of a Django app's static directory.

  1. You'll likely end up statically serving files that aren't meant to be. If the node_modules folder exists in your production environment, running collectstatic will have to check that it's in sync every time, which can be slow due to nodes nested dependency structure. And assuming you have a build step to bundle and transpile your JS, if those source files are within static, they too will be served as static files, for no reason.
  2. You might want to use node for more than just your JavaScript build process. I see you're using Grunt, and you may want to use it to for more than your JavaScript needs, like minifying your css, or running a proxy server around your Django dev server that auto-reloads your browser when files change or the Django server restarts. With this in mind, it might make more sense to think of Node.js as a tool in your build process that could touch any part of your project, the bundling/transpiling of JavaScript being only one part of that.
like image 126
joslarson Avatar answered Oct 06 '22 22:10

joslarson