Cool and powerful effect to select fields. Javascript vanilla and ~2kb gzipped.
DEMO PAGE
npm install pickout --save
bower install pickout --save
Include the style
<link rel="stylesheet" href="./path/to/pickout.min.css">
...
</head>
Include the script
<script src="./path/to/pickout.min.js"></script>
...
</body>
Taking advantage that cdn provides, you can use the pickout in cdnjs to include the files in your page:
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/pickout/1.3.3/pickout.min.css">
...
</head>
<script src="https://cdnjs.cloudflare.com/ajax/libs/pickout/1.3.3/pickout.min.js"></script>
...
</body>
<!-- Normal use -->
<div class="form-group">
<label for="option">Option:</label>
<select name="option" id="option" class="option all" placeholder="Select a option">
<option value=""></option> <!-- If the check is not required, submit a default value empty -->
<option value="opt1">Option 1</option>
<option value="opt2">Option 2</option>
<option value="opt3">Option 3</option>
<option value="opt4">Option 4</option>
</select>
</div>
<!-- Using with icons -->
<div class="form-group">
<label for="suit">Suit:</label>
<select name="suit" id="suit" class="suit all" placeholder="Select a suit">
<option value=""></option> <!-- If the check is not required, submit a default value empty -->
<option data-icon="♠" value="Spade">Spade</option>
<option data-icon="♣" value="Club">Club</option>
<option data-icon="♥" value="Heart">Heart</option>
<option data-icon="♦" value="Diamond">Diamond</option>
</select>
</div>
data-icon
: Icon code, for example: "e602", simply use data-icon=""
;
<!-- Option group -->
<div class="form-group">
<label for="country">Country</label>
<select name="country" id="country" class="country all" placeholder="Select a Country">
<option value=""></option> <!-- If the check is not required, submit a default value empty -->
<optgroup label="America">
<option value="EUA">EUA</option>
<option value="Brazil" selected="selected">Brazil</option>
<option value="Canada">Canada</option>
</optgroup>
<optgroup label="Europe">
<option value="Ireland">Ireland</option>
<option value="Spanish">Spanish</option>
<option value="Italy">Italy</option>
<option value="Portugal">Portugal</option>
</optgroup>
</select>
</div>
pickout.to('.country');
Another option
pickout.to({
el: '.country'
});
OBS: Do not forget to declare the characters responsible dial if class use (.) If ID using the (#)
Field to search options within the modal, default is false
pickout.to({
el: '.country',
search: true
});
You can assign to selects separately, however you can apply all at once, simply declare a class in common to all selects and inform the plugin, for example:
pickout.to('.all');
Simply enter the multiple HTML attribute in the field select what you want
<div class="form-group">
<label for="Skills"><h3>Your skills</h3></label>
<select name="skills[]" id="skills" multiple class="skills" placeholder="Add your Skills">
<option value=""></option> <!-- If the check is not required, submit a default value empty -->
<option value="PHP">PHP</option>
<option value="Ruby">Ruby</option>
<option value="C++">C++</option>
<option value="Scrum">Scrum</option>
<option value="Java">Java</option>
<option value="Cobol">Cobol</option>
<option value="Javascript">Javascript</option>
<option value="AngularJS">AngularJS</option>
<option value="Ionic">Ionic</option>
<option value="VueJS">VueJS</option>
<option value="ReactJS">ReactJS</option>
<option value="React Native">React Native</option>
</select>
</div>
to set the select to pickout
pickout.to('.skills');
For options already selected by default, uses the method
pickout.updatedMultiple('.skills');
With this method the pickout already initializes the tags of options with the selected attribute
To customize, simply add in your CSS rule with this pattern:
.pk-input.-MySelector{
// my customization
}
.pk-arrow.-MySelector{
// my customization
}
And the definition of pickout informs the theme
pickout.to({
el: '.city',
theme: 'MySelector'
});
theme - Modify the visual style, customized through CSS.
- clean (Default)
OBS: You can check or contribute more topics customizam the pickout completely. Theme styles
pickout.to({
el: '.state',
theme: 'dark' // For dark theme, available in dir style themes
});
<div class="form-group">
<label for="state">State:</label>
<select name="state" id="state" class="state all" placeholder="Select to option">
<!-- Option selected by default -->
<option value="opt1" selected>Option 1</option>
<option value="opt2">Option 2</option>
</select>
</div>
It uses the updated function
pickout.updated('.city');
v1.3.0
Yes ✔ | Yes ✔ | 9+ ✔ | Yes ✔ | 8+ ✔ |
v1.3.3
- Fix the arrow style
v1.3.1 / v1.3.2
- Add link Demo Page
- Styles themes
- Correction in modal
v1.3.0
- Multiple options
v1.2.1
- New Style theme
- Correction in modal css
v1.2.0
- Support to option group
- Optimizing for support to IE
- Separation of style themes css files
v1.1.3
- Search field
- Check the open issues or open a new issue to start a discussion around your feature idea or the bug you found.
- Fork repository, make changes, add your name and link in the authors session readme.md
- Send a pull request
If you want a faster communication, find me on @ktquez
thank you