How Can I Show More Than One White Space Character In A Row In A Select2 Data Row?
I'm using Select2 and I use the {data: [{id:1, text: '...'}] approach to define the options. I want to format each option by grouping the substring it's made up of using more than
Solution 1:
Don't you want to use optgroups instead?
{data: [
{
text: "Trees",
children: [
{id:1, text: "Oak"},
{id:2, text: "Pine"},
]
},
{
text: "Seas",
children: [
{id:1, text: "North Sea"},
{id:2, text: "Baltic Sea"},
]
},
]}
or try to add
white-space: pre;
in css-class of select's item to preserve all the whitespaces in the string.
As koenpeters said in comments,for default theme css will look like:
.select2-container--default .select2-results__option {
white-space: pre;
}
Solution 2:
An alternative to the answer that Yuri Gor gave is to use
and include escapeMarkup
to the select2 creation.
$("#isOfTheSelectNode").select2({
escapeMarkup: function (m) { return m; }
});
The drawbacks are:
- None of the html markup will be escaped, which may result in strange
option
elements if the text contains HTML. - Items that contain
will not be matched when you search for a space.
I think Yuri Gor's answer is better if you only want to allow multiple spaces to be rendered as such.
Solution 3:
Add white-space: normal;
to your style
.select2-container .select2-selection--multiple .select2-selection__rendered {
display: inline;
list-style: none;
padding: 0;
white-space: normal;
}
Post a Comment for "How Can I Show More Than One White Space Character In A Row In A Select2 Data Row?"