I have a selector that could look like this:
<label for="testselector">Test</label><br />
<select id="testselector" name="test[]" size="5" multiple="multiple">
<option name="test_1" value="1">Test Entry X</option>
<option name="test_3" value="2">Test Entry Y</option>
<option name="test_5" value="5">Test Entry Z</option>
</select>
<div id="fieldcontainer"></div>
When an entry from the above fields is selected, I want two form fie开发者_开发百科lds to appear. I use jquery to add them:
$("#fieldcontainer").append("<div><label for=\"testurl\">Test Url</label><br /><input name=\"testurl[]\" type=\"text\" id=\"testurl_1\" value=\"\" /></div>");
$("#fieldcontainer").append("<div><label for=\"testpath\">Test Path</label><br /><input name=\"testpath[]\" type=\"text\" id=\"testpath_1\" value=\"\" /></div>");
I can easily add a click handler to make those form fields appear. But how would I keep track of what form fields were already added? When multiple fields are selected, the appropriate number of input fields needs to be added to the fieldcontainer div. And if they are unselected, the input fields need to be removed again. I also need to retrieve the value from the options in the select list to add them as identifier in the added input fields...
When an entry is selected, I would add a class such as "selected" Then you can set the #fieldcontainer's innerHtml based on all of the entries with a class of "selected".
Here the solution I came up with. If there's a more elegant way, let me know. :-)
<script type="text/javascript"><!--
$(document).ready(function(){
function changeVals() {
var values = $("#testselector").val() || [];
$.each(values, function(key, value) {
if(!$("#testurl_"+value).length){
//add field 1
$("#fieldcontainer").append("<div id='testurl_"+value+"'><label>Test URL</label><br /><input name='testurl' type='text' value='...' /></div>");
}
if(!$("#testpath_"+value).length)
{
//add field 2
$("#fieldcontainer").append("<div id='testpath_"+value+"'><label>TEST PATH</label><br /><input name='testpath' type='text' value='...' /></div>");
}
});
//remove all not selected fields
var preg = '';
$.each(values, function(k, v) {
preg = preg + " #testurl_"+v + ",";
preg = preg + " #testpath_"+v + ",";
});
//remove trailing comma
preg = preg.slice(0,preg.length-1);
$("#fieldcontainer > :not("+preg+")").remove();
}
$("#testselector").change(changeVals);
changeVals();
});
//-->
</script>
You could do something along these lines:
// For each of your options
$("#testselector option").each(function(i, option) {
// Create a function that shows/hides the current option
var showHide = function() {
// Find the value of the clicked option
var value = $(option).val();
// Create an id that we can use for adding/removing the new html
var uid = "someuniquename_" + value;
// Check if the option is selected or unselected
// Based on that, either create or remove desired html
if ($(option).attr('selected')) {
$("#fieldcontainer").append('<div id="' + uid + '">your html here, from id ' + value + '...</div>');
} else {
$("#fieldcontainer div#" + uid).remove();
}
};
// Invoke showHide once right now, to initialize the page
showHide();
// Invoke showHide when the option is clicked
$(option).click(showHide);
});
Also note that I'm using single quotes for the html-string, which allows me to write double-quotes without having to escape them. It improves the readability of the code :)
精彩评论