1

我想在 mysql/php 中使用范围滑块进行查询以获取列表。但我不明白如何将变量从 jQuery 传递到 php 文件。我阅读了这个页面和其他页面,但仍然没有得到结果。这是我要传递的 jQuery 代码,我应该怎么做才能传递变量?

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8" />
    <title>jQuery UI Slider - Range slider</title>
    <link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css" />
    <script src="http://code.jquery.com/jquery-1.9.1.js"></script>
    <script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
    <link rel="stylesheet" href="/resources/demos/style.css" />
    <script>
        $(function() {
            $( "#slider-range1" ).slider({
                range: true,
                min: 0,
                max: 500,
                values: [ 75, 300 ],
                slide: function( event, ui ) {
                    $( "#amount1" ).val( "$" + ui.values[ 0 ] + " - $" + ui.values[ 1 ] );
                }
            });
            $( "#amount1" ).val( "$" + $( "#slider-range1" ).slider( "values", 0 ) +
                " - $" + $( "#slider-range1" ).slider( "values", 1 ) );

            $( "#slider-range2" ).slider({
                range: true,
                min: 0,
                max: 500,
                values: [ 75, 300 ],
                slide: function( event, ui ) {
                    $( "#amount2" ).val( "$" + ui.values[ 0 ] + " - $" + ui.values[ 1 ] );
                }
            });
            $( "#amount2" ).val( "$" + $( "#slider-range2" ).slider( "values", 0 ) +
                " - $" + $( "#slider-range2" ).slider( "values", 1 ) );

            $.ajax("file.php", {variable1:/*variable value*/, variable2:/*variable value*/, variable3:/*variable value*/, variable4:/*variable value*/}, /* insert ajax result*/);
        });
    </script>
</head>
<body>
    <p>
        <label for="amount1">Price range:</label>
        <input type="text" id="amount1" style="border: 0; color: #f6931f; font-weight: bold;" />
    </p>
    <div id="slider-range1"></div>
    <p>
        <label for="amount2">Price range:</label>
        <input type="text" id="amount2" style="border: 0; color: #f6931f; font-weight: bold;" />
    </p>
    <div id="slider-range2"></div>
</body>
</html>
4

1 回答 1

2

如果您想在每次更改时提交值,您可以尝试我的代码,但如果您这样做,您就有一个坏主意.. 最好有一个按钮告诉您的服务器客户端已完成价格选择。

我只是更新您的代码,希望对您有所帮助。

    <script>
        $(function() {
            var sliderChangeCallback = function(){
               var amount1 = $( "#amount1" ).val(), amount2 = $( "#amount2" ).val()

               $.ajax({
                   url : "your url",
                   data : {
                       "amount1" : amount1,
                       "amount2" : amount1
                   },
                   error : function(){
                       "call back error"
                   }
               })
            };

            $( "#slider-range1" ).slider({
                range: true,
                min: 0,
                max: 500,
                values: [ 75, 300 ],
                slide: function( event, ui ) {
                    $( "#amount1" ).val( "$" + ui.values[ 0 ] + " - $" + ui.values[ 1 ] );
                    sliderChangeCallback();
                }
            });
            $( "#amount1" ).val( "$" + $( "#slider-range1" ).slider( "values", 0 ) +
                " - $" + $( "#slider-range1" ).slider( "values", 1 ) );

            $( "#slider-range2" ).slider({
                range: true,
                min: 0,
                max: 500,
                values: [ 75, 300 ],
                slide: function( event, ui ) {
                    $( "#amount2" ).val( "$" + ui.values[ 0 ] + " - $" + ui.values[ 1 ] );
                    sliderChangeCallback();
                }
            });
            $( "#amount2" ).val( "$" + $( "#slider-range2" ).slider( "values", 0 ) +
                " - $" + $( "#slider-range2" ).slider( "values", 1 ) );

        });
    </script>
于 2013-11-19T09:06:22.190 回答