gpt4 book ai didi

JQuery slider handle 位置()不起作用

转载 作者:行者123 更新时间:2023-12-01 01:30:11 25 4
gpt4 key购买 nike

我有一个 div,它显示 slider 的当前值,并且 div 随 slider 位置移动。

基于 Using offset and jQuery slider 的答案

我想出了以下代码:

function SliderSetup()
{
$("#slider").slider({
value:0,
min: -10,
max: 10,
step: 2,
animate:false,
slide: function(event, ui) {
setTimeout(showVal, 10);
}
});

$("#slider").slider("value", 0);
showVal(); //setTimeout(showVal, 10) does not work either
}

function showVal() {

var position = $('.ui-slider-handle:first').position(); //i tried offset()-didnt work
var value = $('#slider').slider('value');
$('#value1').text(value).css({'left':position.left});
}

当用户使用 slider 时,div 位置是正确的,但默认情况下该值不在正确的位置。截图如下

alt text

编辑:标记

                                <tr>
<td width="30%">
<h2>
Select Value</h2>
</td>
<td width="60%">
<div id="value1">&nbsp;</div>
<div id="slider">
</div>
</td>
<td>
<div id="myDiv">
</div>
</td>
</tr>

最佳答案

我认为您的标记有问题(初始值元素宽度?),或者在元素准备好后没有触发此问题。无论如何,这是一个完整的工作示例:

<html>
<head>
<title>Test</title>
<link href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/themes/ui-lightness/jquery-ui.css" rel="stylesheet" />
<style type="text/css">
</style>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/jquery-ui.min.js"></script>
<script type="text/javascript">
function SliderSetup()
{
$("#slider").slider({
value:0,
min: -10,
max: 10,
step: 2,
animate:false,
slide: function(event, ui) {
setTimeout(showVal, 10);
}
});
$("#slider").slider("value", 0);
showVal();
}
function showVal() {
var slider = $('.ui-slider-handle:first');
var position = slider.offset();
var value = $('#slider').slider('value');
var val = $('#value1');
val.text(value).css({'left':position.left + ((slider.width() - val.width()) /2), 'top':position.top -20 });
}
$(function(){
SliderSetup();
});
</script>
</head>
<body>
<br/><br/><br/>
<div id="value1" style="position: absolute"></div>
<div id="slider"></div>
</body>
</html>

代码间隔很大,希望能帮助您更快地找到问题。 css 的更改只是我将值更精确地集中在 slider 顶部,当然可以更改为您想要的任何位置。要检查值元素的宽度,请尝试定义此 css,这可能是您唯一的问题,在没有看到标记的情况下无法确定:

#value1 { border: solid 1px red; }

关于JQuery slider handle 位置()不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2397397/

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