Search code examples
node.jsexpresscheckboxbooleanpug

Node Express Jade - Checkbox boolean value


I'm using Node+Express+Jade to render some webpages. On a form there are 2 checkboxes. When the form is submitted through POST, if the checkbox is checked, I get req.body.checkbox1 -> 'on', if isn't checked, I get req.body.checkbox1 -> undefined

Is possible to get checkbox value as true or false ?

Here's my server side test code

var bodyParser = require('body-parser');
var express = require('express');

var app = express();
app.use(bodyParser.urlencoded({extended: true}));
app.use(express.static(__dirname + '/webroot'));
app.set('views', __dirname + '/view');
app.set('view engine', 'jade');
app.listen(3001);
app.get('/', function (req, res) {
    res.render('test');
});

app.post('/config', function (req, res) {
    console.log(req.body.t);
    console.log(req.body.f);
    res.redirect('/');
});

And my Jade form test

form(action='/config', method='post')
    input(type="checkbox", name="not_checked", checked=false)
    input(type="checkbox", name="checked", checked=true)
    input(type='submit')

Solution

  • Can you try the following jade form

    form(action='/survey/submission/test/config', method='post')
      input(type="checkbox", name="not_checked", value="false")
      input(type="checkbox", name="checked", checked, value="true")
      input(type='submit')
    

    The value will be string, so you have to parse it. If the checkbox does not have checked attribute then it would not be included in the post request body. So in the above form, only the checked checkbox will be sent see below.

    req.body : {"checked":"true"}
    

    If you tick both checkboxes then both values will be sent as below

    req.body : {"not_checked":"false","checked":"true"}
    

    You can also add validation against undefined, whenever no checkbox is ticked

       if(req.body.not_checked) {
          console.log('not checked : ' + req.body.not_checked);
        }
    
        if(req.body.checked) {
          console.log('checked : ' + req.body.checked);
        }