英文:
How to change position of chevron on <select> with Tailwind?
问题
I have a classic select
input which receives an array of strings.
问题是,chevron 位于 select 的绝对右侧,靠近边框。
我想将其位置向左移动一点。
如何在 Tailwind 中实现?
这是一个 Tailwind playground
这是代码:
<div class="m-8">
<select class="h-10 w-full rounded border border-solid border-neutral-300 px-4 text-sm">
<option value="none">None</option>
{list?.map((item) => (
<option key="{item}" value="{item}">{item}</option>
))}
</select>
</div>
英文:
I have a classic select
input which receive an array of strings.
Problem, the chevron is on absolute right of the select, against the border.
I want to move its poition to the left a little.
How to achieve that with tailwind ?
Here is a Tailwind playground
Here is the code :
<div class="m-8">
<select class="h-10 w-full rounded border border-solid border-neutral-300 px-4 text-sm">
<option value="none">None</option>
{list?.map((item) => (
<option key="{item}" value="{item}">{item}</option>
))}
</select>
</div>
答案1
得分: 2
We can't add padding to the default select arrow. The workaround you can do is use outline
property. You can achieve this using the following code.
<div class="m-8">
<select class="h-10 w-full rounded border-r-8 border-transparent px-4 text-sm outline outline-neutral-700">
<option value="none">Non précisée</option>
{list?.map((item) => (
<option key="{item}" value="{item}">{item}</option>
))}
</select>
</div>
Here, we are giving a border to just the right side and setting it to 8px of width. This will work as padding after we add the outline. Don't forget to set the border color to transparent. Then add the outline property and set the color you want to outline. This will create the same effect that you wanted with border and padding.
Here's the tailwind playground
英文:
We can't add padding to the default select arrow. The workaround you can do is use outline
property. You can achieve is using following code.
<div class="m-8">
<select class="h-10 w-full rounded border-r-8 border-transparent px-4 text-sm outline outline-neutral-700">
<option value="none">Non précisé</option>
{list?.map((item) => (
<option key="{item}" value="{item}">{item}</option>
))}
</select>
</div>
Here, we are giving border to just the right side and setting it to 8px of width. This will work as a padding after we add the outline. Don't forget to set border colour to transparent. Then add outline property and set the colour you want to outline. This will create the same effect that you wanted with border and padding.
Here's the tailwind playground
答案2
得分: 0
以下是翻译好的内容:
"select" 元素很难进行样式化。为了获得更多自由,我会选择自制下拉菜单。
另外,总是有一些 CSS 技巧:
HTML:
<select class="form-select appearance-none pr-8 pl-2 bg-no-repeat">
<option>选项 1</option>
<option>选项 2</option>
<option>选项 3</option>
</select>
CSS:
.form-select {
background-image: url('');
background-size: 0.7rem;
background-position: right 0.7rem center;
}
英文:
The "select" elements are complicated to style. For more freedom I would opt for a home made dropdown.
Otherwise there are always some css tricks:
https://play.tailwindcss.com/rOgId32XZx
HTML :
<select class="form-select appearance-none pr-8 pl-2 bg-no-repeat">
<option>Option 1</option>
<option>Option 2</option>
<option>Option 3</option>
</select>
CSS:
.form-select {
background-image: url('');
background-size: 0.7rem;
background-position: right 0.7rem center;
}
通过集体智慧和协作来改善编程学习和解决问题的方式。致力于成为全球开发者共同参与的知识库,让每个人都能够通过互相帮助和分享经验来进步。
评论