Bootstrap下拉列表与滑块jquery ui发生冲突

时间:2017-12-14 07:00:46

标签: javascript php jquery twitter-bootstrap opencart

我的OpenCart 2.3项目遇到了一些问题。我来简要介绍一下。

在产品详情页面中,基本上是catalog -> view -> product -> category.tpl,我正在使用货币模块和过滤模块。

参见图片以供参考

enter image description here

当我使用滑块过滤我的产品列表时,它会刷新页面数据(注意:此页面没有重新加载),但货币下拉列表无效。

如果我再次使用滑块,则下拉列表正在工作。

表示:第一次加载页面后。如果我使用滑块,那么对于每个奇数转弯,滑块都在工作,对于每个偶数转弯,滑块都不起作用。

现在你对这个问题了解不多。

让我们来到编码部分。

我在module -> filter.tpl档案中。 这里为滑块编写了这个jquery

$("#slider-range").slider({});

在滑块功能中,一个对象正在传递,如下所示:

$("#slider-range").slider({
    range: true,
    min: <?php echo $min_product_price ; ?>,
    max: <?php echo $max_product_price; ?>,
    values: [ <?php echo $amount_min; ?>, <?php echo $amount_max; ?> ],
    create: function (event, ui) {
        $("#amount").val("<?php echo $currency_symbol; ?> " + $("#slider-range" ).slider( "values", 0 ) +"  -  <?php echo $currency_symbol; ?> " +
        $("#slider-range").slider("values", 1 ) );
        $('#amtmin').text('<?php echo $currency_symbol; ?> '+$("#slider-range").slider("values")[0]);
        $('#amtmax').text('<?php echo $currency_symbol; ?> '+$("#slider-range").slider("values")[1]);
      },
    slide: function( event, ui ) {
        $('#amtmin').text('<?php echo $currency_symbol; ?> '+$("#slider-range").slider("values")[0]);
        $('#amtmax').text('<?php echo $currency_symbol; ?> '+$("#slider-range").slider("values")[1]);
        $("#slider-range").val( "<?php echo $currency_symbol; ?> " + ui.values[ 0 ] + "  -  <?php echo $currency_symbol; ?> " + ui.values[ 1 ] );
      },
    stop: function (event, ui) {
        filter = [];
        $('input[name^=\'filter\']:checked').each(function(element) {
              filter.push(this.value);
            });
        amount=[];
        var amtmin = ui.values[0];
        var amtmax = ui.values[1];
        amount.push(amtmin,amtmax);
        $('#amtmin').text("<?php echo $currency_symbol; ?> "+$("#slider-range").slider("values")[0]);
        $('#amtmax').text("<?php echo $currency_symbol; ?> "+$("#slider-range").slider("values")[1]);
        window.history.pushState("","",'<?php echo $action; ?>&filter=' + filter.join(',')+'&amtmin=' + amtmin+'&amtmax='+amtmax);
        $("body").load('<?php echo $action; ?>&filter=' + filter.join(',')+'&amtmin=' + amtmin+'&amtmax='+amtmax);
        // window.location.href = '<?php echo $action; ?>&filter=' + filter.join(',')+'&amtmin=' + amtmin+'&amtmax='+amtmax;
    }
});

专注于这一行:

$("body").load('<?php echo $action; ?>&filter=' + filter.join(',')+'&amtmin=' + amtmin+'&amtmax='+amtmax);

这行代码基本上是在我的body标签中加载一个新url,请注意,我的标题,我的货币都在正文中。 我不知道这段代码发生了什么。因此,一次性货币下拉工作正在进行,而另一次则没有。

另外我想说点什么,你可以看到最后一个评论行。

window.location.href = '<?php echo $action; ?>&filter=' + filter.join(',')+'&amtmin=' + amtmin+'&amtmax='+amtmax;

如果我正在加载新文档(基本上是重新加载),那么一切都很好。

但我不想重新加载页面。 你能帮助我吗?

1 个答案:

答案 0 :(得分:0)

您好请将您的最低和最高价格放在下面的代码中

$this->currency->format((float)$min_product_price ? $min_product_price : $min_product_price , $min_product_price)

$this->currency->format((float)$max_product_price ? $max_product_price : $max_product_price , $max_product_price )

注意:您需要将这些行放在controller/product/category.php