gpt4 book ai didi

javascript - 在 HTML 选择列表中选择选项时的 HTML 垂直居中选择

转载 作者:行者123 更新时间:2023-11-30 17:35:40 24 4
gpt4 key购买 nike

我有以下 HTML 代码:

<select name="" id="listF" size="10">
<option value="01">001</option>
<option value="02">002</option>
<option value="03">003</option>
<option value="04">004</option>
<option value="05">005</option>
<option value="06">006</option>
<option value="07">007</option>
<option value="08">008</option>
<option value="09">009</option>
<option value="10">010</option>
<option value="11">011</option>
<option value="12">012</option>
<option value="13">013</option>
<option value="14">014</option>
<option value="15">015</option>
<option value="16">016</option>
<option value="17">017</option>
<option value="18">018</option>
<option value="19">019</option>
<option value="20">020</option>
<option value="21">021</option>
<option value="22">022</option>
<option value="23">023</option>
<option value="24">024</option>
</select>

我有以下 JavaScript

$('#listF').click(function(){
var n = 10;
if(this.selectedIndex < ($(this).find('option').length-n)) {
this.selectedIndex+=n;
this.selectedIndex-=n;
}
});

选择的 HTML 长度是 10 - 我希望每当我选择一个选项时它垂直居中(而不是水平)说它将显示在第 5 个例如

Option 1 
Option 2
Option 3
Option 4
Option 5
Option 6
Option 7
Option 8
Option 9
Option 10

如果我选择选项 12 - 选项 12 将居中

Option 8
Option 9
Option 10
Option 11
Option 12 <<<<<Centered
Option 13
Option 14
Option 15
Option 16
Option 17

假设我选择选项 7 - 选项 7 将居中

Option 3
Option 4
Option 5
Option 6
Option 7 <<<<<Centered
Option 8
Option 9
Option 10
Option 11
Option 12

我如何修改我的 javascript 以实现此目的?

我想将 <option> 垂直居中相对于 <select>

最佳答案

Demo

$('#listF').on('change', function(){
var n = this.getAttribute('size'),
i = this.selectedIndex,
l = this.options.length;
this.selectedIndex = Math.min(l-1, i+n/2|0);
this.selectedIndex = Math.max(0, i+1-n/2|0);
this.selectedIndex = i;
});

测试了奇数和偶数尺寸。

关于javascript - 在 HTML 选择列表中选择选项时的 HTML 垂直居中选择,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22130926/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com