mirror of
https://github.com/bigskysoftware/htmx.git
synced 2026-03-26 04:40:23 +00:00
2.8 KiB
2.8 KiB
layout
| layout |
|---|
| demo_layout.njk |
Value Select
In this example we show how to make the values in one select depend on the value selected in another select.
To begin we start with a default value for the make select: Audi. We render the model select for this make. We
then have the make select trigger a GET to /models to retrieve the models options and target the models select.
Here is the code:
<div>
<label >Make</label>
<select name="make" hx-get="/models" hx-target="#models" hx-indicator=".htmx-indicator">
<option value="audi">Audi</option>
<option value="toyota">Toyota</option>
<option value="bmw">BMW</option>
</select>
</div>
<div>
<label>Model</label>
<select id="models" name="model">
<option value="a1">A1</option>
...
</select>
</div>
When a request is made to the /models end point, we return the models for that make:
<option value='325i'>325i</option>
<option value='325ix'>325ix</option>
<option value='X5'>X5</option>
And they become available in the model select.
{% include demo_ui.html.liquid %}
<script> //========================================================================= // Fake Server Side Code //========================================================================= // routes init("/demo", function(request, params){ return formTemplate(); }); onGet(/models.*/, function (request, params) { var make = dataStore.findMake(params['make']); return modelOptionsTemplate(make['models']); }); // templates function formTemplate() { return `Pick A Make/Model
Make
Audi
Toyota
BMW
`;
}
function modelOptionsTemplate(make) {
return make.map(function(val) {
return "" + val +"";
}).join("\n");
}
var dataStore = function(){
var data = {
audi : { models : ["A1", "A4", "A6"] },
toyota : { models : ["Landcruiser", "Landcruiser", "Landcruiser"] },
bmw : { models : ["325i", "325ix", "X5"] }
};
return {
findMake : function(make) {
return data[make];
}
}
}()
</script>