mardi 20 juin 2017

Toggle Checkbox upon clicking on Span

I'm working on an assignment that needs to, upon the click of a span element's text in an input div, output the same text in an output div. That part I've done successfully, but to the left of each span element within the input div is a checkbox that needs to also be checked upon the click of said span element. I am not allowed to target each individual checkbox with its own unique ID because I will be adding in newer checkboxes and span elements later with the press of a button and prompt. This is an assignment on event delegation. I will then need to be able to uncheck the checkbox and remove the appended output, but first thing's first, I cannot figure out how to target the checkboxes. The only thing I can think of is to somehow say that whatever index number of said span element was clicked would be the index number of said checkbox is clicked, but I'm unsure if that is the best method as well as how to go about doing that. Also, this assignment should not have any JQuery involved. My next project is actually to redo this assignment in JQuery. Any help would be appreciated!

HTML:

<!DOCTYPE html>
<html>

<head>
    <title>Canvas Document Object Model Exercise</title>
    <link rel="stylesheet" href="canvas_stylesheet.css">
</head>

<body>
    <div id="input">
        <form>
            <input class="checkbox" type="checkbox"><span class="values">Apple</span></br></br>
            <input class="checkbox" type="checkbox"><span class="values">Mango</span></br></br>
            <input class="checkbox" type="checkbox"><span class="values">Grape</span></br></br>
            <input class="checkbox" type="checkbox"><span class="values">Strawberry</span></br></br>
            <input class="checkbox" type="checkbox"><span class="values">Cherry</span>
        </form>
    </div>

    <div id="output"></div>

CSS:

#input {
    width: 250px;
    height: 300px;
    float: left;
    padding: 20px 0 30px 15px;
    border-style: solid;
    border-color: black;
    border-width: 1px;
}

.values {
    display: inline;
}

/*
#input form input {
    padding: 20px 20px 20px 20px;
}
*/

#output {
    width: 225px;
    height: 326px;
    float: left;
    border-top: 1px solid black;
    border-right: 1px solid black;
    border-bottom: 1px solid black;
    padding: 4px 20px 20px;
}

JS:

window.onload = UncheckAll;
function UncheckAll() { 
    var w = document.getElementsByTagName('input'); 
    for (var i = 0; i < w.length; i++) { 
        if (w[i].type == 'checkbox') { 
            w[i].checked = false; 
        }
    }
}

document.getElementById("input").addEventListener("click", function(e){
    if (e.target.nodeName === "SPAN") {
        var node = document.createElement("P");
        var textnode = document.createTextNode(e.target.innerHTML);

        node.appendChild(textnode);
        document.getElementById("output").appendChild(node);
        node.setAttribute("class", "outputItem")
    }
});




Aucun commentaire:

Enregistrer un commentaire