Search code examples
djangovue.jsvuejs2webpack-dev-servervue-loader

Vue and Django Development Environment


I just started a new little project for learning purposes and I want to try out Vue js with Django (with DRF). I'm trying to use vue loader (webpack-simple template).

The problem is that I don't know how to synchronize npm run dev and python manage.py runserver. I don't know how to access a template that is rendered by django in webpack-dev-server.

I mean I have a template with django-template specific keywords like {% load static %} that is not handled by webpack-dev-server, obviously.

I know I can build it everytime npm run build, but that's kinda annoying and boring to wait for it everytime I want to make a little change.

In webpack, it's specified to run on a default index.html file, how can I make it work on the template that is actually rendered on 127.0.0.1:8000 with python manage.py runserver running? I know it doesn't make any sense to run 2 dev servers, but I don't know how to explain in other way.

Is there an alternative?

Thanks in advance for answers!


Solution

  • Run your Django server as normal. webpack shouldn't serve your files. It should just build them (use webpack development settings and webpack --watch) and let webpack put them in the static directory of your Django project, e.g.

    // in your webpack config
    output: {
        path: path.resolve(__dirname, 'project/static/js')
    }
    

    That way Django can serve the files that are run through your webpack pipeline.

    On top you can use the webpack live reload plugin and the live reload browser extension to auto-reload when your assets change.

    When you are ready to commit your changes, build your files in production mode and commit the build files in the static dir.