热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

bootstrapslider插件使用方法

bootstrap-slider例子地址:https:seiyria.combootstrap-sliderbootstrap-slidergithub地址:htt

bootstrap-slider例子地址:https://seiyria.com/bootstrap-slider/

bootstrap-slider github地址:https://github.com/seiyria/bootstrap-slider

这个插件的使用方法并不难,我们可以在它的例子页面看到很多种情况的使用方法,都给了相应的代码。我就简述一下在使用过程中遇到的一些坑及解决办法。

我们需要实现的功能如下图所示:

 

简而言之就是,选择之后实时将你选中的数据返回到文本框里面。

 

解决思路:

1.点击文本框 显示 浮层(这里有个坑,我后面会讲到);

2.实例化 拖动 插件;

3.将 选中的值 实时返回到文本框(这里也有个坑)。

 

解决方案:

解决问题1——点击文本框 显示 浮层

因为项目是基于bootstrap,所以我直接用的是 bootstrap 的下拉菜单插件,具体代码如下:

<div class="form-group btn-group">
   <div class="input-icon right dropdown-toggle " data-toggle="dropdown">
       <i class="fa fa-angle-down font-blue">i>
       <input type="text" class="form-control input-small" placeholder="请选择年龄段" id="ageValue">
   div>
    <div class="dropdown-menu dropdown-content" role="menu">
            <input id="ageSlider" type="text" data-stopPropagation="true"
                   data-slider-min="0"
                   data-slider-max="50"
                   data-slider-step="0.5"
                   data-slider-value="[2,5]"
                   data-slider-tooltip="hide"/>
    div>
div>

其中里面的data-slider-XXX 是针对于bootstrap-slider插件定义的一些属性,具体可以查看它的github地址,上面都有详细的说明。如下图:

 

 解决问题2——实例化 拖动 插件

var ageSlider = $("#ageSlider").bootstrapSlider()

这里要说明一下的就是,如果你不是依赖于bootstrap开发的话,需要写成下面这个:

//引用了jquery的时候
var
ageSlider = $("#ageSlider").slider({})

//没有引用jquery的时候
var ageSlider = new Slider(\'#ageSlider\', {});

 

解决问题3——将 选中的值 实时返回到文本框

解决思路就是在值改变的时候,返回一个函数,函数的作用是把值写入到文本框里面。

我们如何捕获到它的值改变了呢?我们可以看到插件提供了一个change事件:

 

我们怎么获取到slider的值呢?插件提供了一个 getValue 的方法:

接下来就好办了,直接把值写入到文本框里面就可以了。具体代码如下:

var ageChange = function() {
    var ageArr = ageSlider.bootstrapSlider(\'getValue\');
    $(\'#ageValue\').val(ageArr[0]+\'岁\' + \'~\' + ageArr[1]+\'岁\');
};
var ageSlider = $("#ageSlider").bootstrapSlider().on(\'change\',ageChange);

 

功能实现基本就到这里了。

 

-------我是天堂与地狱之间的分隔线了-------

 

接下来说下我遇到的坑。。。各位看官有兴趣也可以继续看下去。。毕竟这也是一条充满血与泪的路哇。能够让你少走弯路。

坑一:解决问题一的时候,发现一个问题,就是你在拖动结束之后浮层就会隐藏掉。如下图:

解决方法就是点击浮层的时候,阻止它的隐藏事件。代码如下:

$(\'.dropdown-menu\').click(function(e) {
    e.stopPropagation();
});

.dropdown-menu 是那个浮层:

解决方案来自于:Keep Bootstrap dropdown open on click

 

坑二:解决问题3时,报错:getValue is not a function。

一开始,我是按照官方的案例getValue()来写的。如下图:

我开始是这么写的,如下图:

然后就报错了。。。

后面看它的官方文档,才知道要按照下图这么写:

 

 好了,该交待的都已交待完毕啦~~感觉自己棒棒哒~

最后来份代码全家福压压惊~

 

 


推荐阅读
  • 本文详细探讨了 jQuery 中 `ajaxSubmit` 方法的使用技巧及其应用场景。首先,介绍了如何正确引入必要的脚本文件,如 `jquery.form.js` 和 `jquery-1.8.0.min.js`。接着,通过具体示例展示了如何利用 `ajaxSubmit` 方法实现表单的异步提交,包括数据的发送、接收和处理。此外,还讨论了该方法在不同场景下的应用,如文件上传、表单验证和动态更新页面内容等,提供了丰富的代码示例和最佳实践建议。 ... [详细]
  • com.sun.javadoc.PackageDoc.exceptions()方法的使用及代码示例 ... [详细]
  • oracle c3p0 dword 60,web_day10 dbcp c3p0 dbutils
    createdatabasemydbcharactersetutf8;alertdatabasemydbcharactersetutf8;1.自定义连接池为了不去经常创建连接和释放 ... [详细]
  • [转]doc,ppt,xls文件格式转PDF格式http:blog.csdn.netlee353086articledetails7920355确实好用。需要注意的是#import ... [详细]
  • javascript分页类支持页码格式
    前端时间因为项目需要,要对一个产品下所有的附属图片进行分页显示,没考虑ajax一张张请求,所以干脆一次性全部把图片out,然 ... [详细]
  • 字节流(InputStream和OutputStream),字节流读写文件,字节流的缓冲区,字节缓冲流
    字节流抽象类InputStream和OutputStream是字节流的顶级父类所有的字节输入流都继承自InputStream,所有的输出流都继承子OutputStreamInput ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 本文深入解析了 jQuery 中用于扩展功能的三个关键方法:`$.extend()`、`$.fn` 和 `$.fn.extend()`。其中,`$.extend()` 用于扩展 jQuery 对象本身,而 `$.fn.extend()` 则用于扩展 jQuery 的原型对象,使自定义方法能够作为 jQuery 实例的方法使用。通过这些方法,开发者可以轻松地创建和集成自定义插件,增强 jQuery 的功能。文章详细介绍了每个方法的用法、参数及实际应用场景,帮助读者更好地理解和运用这些强大的工具。 ... [详细]
  • 本文探讨了使用JavaScript在不同页面间传递参数的技术方法。具体而言,从a.html页面跳转至b.html时,如何携带参数并使b.html替代当前页面显示,而非新开窗口。文中详细介绍了实现这一功能的代码及注释,帮助开发者更好地理解和应用该技术。 ... [详细]
  • 本文全面解析了JavaScript中的DOM操作,并提供了详细的实践指南。DOM节点(Node)通常代表一个标签、文本或HTML属性,每个节点都具有一个nodeType属性,用于标识其类型。文章深入探讨了DOM节点的创建、查询、修改和删除等操作,结合实际案例,帮助读者更好地理解和掌握DOM编程技术。 ... [详细]
  • 本文探讨了如何在 Java 中将多参数方法通过 Lambda 表达式传递给一个接受 List 的 Function。具体分析了 `OrderUtil` 类中的 `runInBatches` 方法及其使用场景。 ... [详细]
  • 本文介绍如何在 Android 中自定义加载对话框 CustomProgressDialog,包括自定义 View 类和 XML 布局文件的详细步骤。 ... [详细]
  • 原文网址:https:www.cnblogs.comysoceanp7476379.html目录1、AOP什么?2、需求3、解决办法1:使用静态代理4 ... [详细]
  • com.hazelcast.config.MapConfig.isStatisticsEnabled()方法的使用及代码示例 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
author-avatar
112473228
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有