Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/haggen/populous
Populates a <select> with a remote JSON.
https://github.com/haggen/populous
ajax dropdown javascript
Last synced: 2 months ago
JSON representation
Populates a <select> with a remote JSON.
- Host: GitHub
- URL: https://github.com/haggen/populous
- Owner: haggen
- Created: 2013-04-23T14:27:41.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2016-02-23T01:08:56.000Z (almost 9 years ago)
- Last Synced: 2024-10-03T09:45:31.696Z (4 months ago)
- Topics: ajax, dropdown, javascript
- Language: JavaScript
- Homepage:
- Size: 27.3 KB
- Stars: 40
- Watchers: 8
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Populous
> Populates a `` with a remote JSON.
## Working Example
http://jsfiddle.net/haggen/7tS3e/27/
## Usage
`index.html`:
```html$('select').populous('load');
```
`options.json`:
```javascript
["Banana", "Apple", "Grape", "Cranberry"]
```Bam! Your `` now has 4 options: `Banana`, `Apple`, `Grape` and `Cranberry`.
## Configuration
You can customize the options by providing a hash when calling the plugin, like this:
```javascript
$('select').populous({...});
```### AJAX
To configure the AJAX request, provide a `source` option with regular [jQuery AJAX settings](http://api.jquery.com/jQuery.ajax/#jQuery-ajax-settings):
```javascript
$('select').populous({
source: {
url: '/basket',
method: 'POST',
data: {all: 'fruits'}
}
});
```Note that, by default, the method is `GET`, and the URL can be set using the attribute `data-source-url` on the `` element.
### Mapping the response
Populous use a `map` function to handle the response.
```javascript
function(response) {
return [];
}
```The resulting array may comprise arrays (pairs of label and value, in that order) or strings (that will be used as both).
Below is the default `map` option:
```javascript
function(response) {
return $.map(response, function(label) {
return [[label, label]]; // jQuery#map make it flat, so we add depth
});
}
```But you can provide your own mapping function:
```javascript
$('select').populous({
map: function(response) {
return [];
}
});
```## API
### Events and states
There are 2 new events being fired - `loading` and `loaded` - that happens, respectively, right before the AJAX request and right after the `` is populated with its response.
```javascript
$('select').on('loading', function() {
$(this).attr('disabled', true);
});$('select').on('loaded', function() {
$(this).attr('disabled', false);
});
```Also, there's a data property being set to flag when it's loading.
```javascript
if($('select').data('loading')) {
alert('Wait!');
} else {
alert('Ready!');
}
```### Updating value
Populous does a little patch to allow jQuery's standard method `val` to seamlessly update the `` even when it isn't finished loading.
```javascript
$('select').populous('load');
$('select').val('Hey!'); //=> Will update when finish loading.
```### AMD
If you like [RequireJS](http://requirejs.org) you can easily make a module definition for Populous.
```javascript
define('Populous', ['jquery'], function($) {this.jQuery = $;
// Paste here the contents of populous.js
});
```## License
See [CC Attribution-ShareAlike 4.0 International](http://creativecommons.org/licenses/by-sa/4.0/deed.en_US)
## Contribution
1. Fork it
2. Change it
3. Commit with brief yet meaningful description
4. Send pull requestAlso, you could report an issue, help to fix or simply comment in one.