Bootstrap模块dropdown实现下拉框响应


Posted in Javascript onMay 22, 2016

本文介绍了Bootstrap下拉框模块dropdown的使用方法,供大家参考,具体内容如下

一、源码分析:
Dropdowns.scss:
下拉框模块
Javascripts/bootstrap/dropdown.js:实现下拉框响应

二、功能及原理:
下拉选项卡,默认不能实现显示选中项的功能

原理:

1、利用dropdown类作为定位点,然后让子级的列表dropdown-menu绝对定位实现,还需要加一个单击点作为设置data-toggle=”dropdown”才能做关联。
2、 需要js插件的支持

三、源码分析:
1、caret:实现向下的三角形,利用边框实现的
    1.1、边框颜色默认是字体颜色
    1.2、三角形的实现:边框要有宽度,然后相邻两边需有宽度,但颜色透明;最后还需要元素为行内块元素,才能使其高、宽为0。
    1.3、代码如下

<span style="border-left: 4px solid; border-top: 4px solid transparent; border-bottom: 4px solid transparent; height: 0px; width: 0px; line-height: normal; display: inline-block; "></span>

2、在document上绑定了click事件的监听,监听类型为data-toggle=”dropdown”。
3、Js插件写的Plugin函数,和类的构造函数是用于js方式调用插件;
4、而data-*模式调用插件,用到是向document注入事件实现的,代码如下:

$(document)
.on('click.bs.dropdown.data-api', clearMenus)
.on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
.on('click.bs.dropdown.data-api', toggle, Dropdown.prototype.toggle)
.on('keydown.bs.dropdown.data-api', toggle, Dropdown.prototype.keydown)
.on('keydown.bs.dropdown.data-api','.dropdown-menu',Dropdown.prototype.keydown)

代码直接调用了Dropdown定义的方法,这里经妙的设计在于插件的框架,data-*模式的调用与Js插件模式的调用,而这两种调用模式却利用了同一份代码。
5、如果用Js插件调用,基础方法都要自己调用才行,在创建实例时只会绑定toggle事件。

var Dropdown = function (element) {
 $(element).on('click.bs.dropdown', this.toggle)
}

6、clearMenu:只会清除data-toggle=”dropdown”的元素
7、dropdown-backdrop:用于移动没有单击事件的处理
8、keydown:当dropdown按钮获取焦点的时候,按下键可以展开,按上键收缩的功能
9、data-target和herf=”#id”:是为了实现单击,展开指定的下拉列表,默认是展开与按钮后面兄弟节点:

<ul class="nav nav-pills navbar-nav">
 <li><a>Index</a></li>
 <li><a>产吕</a></li>
 <li > <a data-toggle="dropdown" href="#name" >实用工具</a></li>
</ul>
<div id="name" >
 <ul class="dropdown-menu" >
 <li><a>关于我们</a></li>
 </ul>
</div>

10、实现向上弹出子菜单,用bottom:100%(弹出子菜单bottom的定位)实现
11、应用示例

<div id="dropdown" class="dropdown">
<a id="dropdown-btn" data-target="#dropdown" >number</a>
<ul class="dropdown-menu" >
 <li><a>3343</a></li>
<li><a>555</a></li>
</ul>
</div>

如果大家还想深入学习,可以点击这里进行学习,再为大家附两个精彩的专题:Bootstrap学习教程 Bootstrap实战教程

以上就是本文的全部内容,希望对大家学习javascript程序设计有所帮助。

Javascript 相关文章推荐
javascript支持firefox,ie7页面布局拖拽效果代码
Dec 20 Javascript
javascript Array.remove() 数组删除
Aug 06 Javascript
javascript 解决表单仍然提交即使监听处理函数返回false
Mar 14 Javascript
jquery调用wcf并展示出数据的方法
Jul 07 Javascript
javascript判断ie浏览器6/7版本加载不同样式表的实现代码
Dec 26 Javascript
js动态创建、删除表格示例代码
Aug 07 Javascript
js实现的复制兼容chrome和IE
Apr 03 Javascript
详解vue 不同环境配置不同的打包命令
Apr 07 Javascript
微信小程序实现点击效果
Jun 21 Javascript
Layui实现主窗口和Iframe层参数传递
Nov 14 Javascript
基于vue-draggable 实现三级拖动排序效果
Jan 10 Javascript
JS实现无限轮播无倒退效果
Sep 21 Javascript
基于Bootstrap实现图片轮播效果
May 22 #Javascript
基于Vue.js的表格分页组件
May 22 #Javascript
js正则表达式replace替换变量方法
May 21 #Javascript
深入解析JavaScript中的立即执行函数
May 21 #Javascript
详解JavaScript中Hash Map映射结构的实现
May 21 #Javascript
简单掌握JavaScript中const声明常量与变量的用法
May 21 #Javascript
基于javascript实现表格的简单操作
May 21 #Javascript
You might like
创建配置文件 用PHP写出自己的BLOG系统 2
2010/04/12 PHP
php下连接mssql2005的代码
2011/01/17 PHP
TMDPHP 模板引擎使用教程
2012/03/13 PHP
使用Discuz关键词服务器实现PHP中文分词
2014/03/11 PHP
PHP中创建图像并绘制文字的例子
2014/11/19 PHP
Javascript中的常见排序算法
2007/03/27 Javascript
让你的博文自动带上缩址的实现代码,方便发到微博客上
2010/12/28 Javascript
基于jquery的15款幻灯片插件
2011/04/10 Javascript
Jquery操作下拉框(DropDownList)实现取值赋值
2013/08/13 Javascript
js获取窗口相对于屏幕左边和上边的位置坐标
2014/05/15 Javascript
JavaScript结合AJAX_stream实现流式显示
2015/01/08 Javascript
js类式继承与原型式继承详解
2016/04/07 Javascript
jQuery实现获取table中鼠标click点击位置行号与列号的方法
2017/10/09 jQuery
React Native 搭建开发环境的方法步骤
2017/10/30 Javascript
js实现HTML中Select二级联动的实例
2018/01/05 Javascript
JavaScript常用事件介绍
2019/01/21 Javascript
Vue和React组件之间的传值方式详解
2019/01/31 Javascript
详解vue 路由跳转四种方式 (带参数)
2019/04/28 Javascript
使用vue-router切换页面时实现设置过渡动画
2019/10/31 Javascript
JavaScript This指向问题详解
2019/11/25 Javascript
详解React 条件渲染
2020/07/08 Javascript
python求crc32值的方法
2014/10/05 Python
Python 通配符删除文件的实例
2018/04/24 Python
python 产生token及token验证的方法
2018/12/26 Python
Python安装依赖(包)模块方法详解
2020/02/14 Python
Python headers请求头如何实现快速添加
2020/11/03 Python
使用phonegap克隆和删除联系人的实现方法
2017/03/31 HTML / CSS
意大利制造的男鞋和女鞋:SCAROSSO
2018/03/07 全球购物
微软美国官方网站:Microsoft美国
2018/05/10 全球购物
节能宣传周活动总结
2014/05/08 职场文书
职务任命书范本
2014/06/05 职场文书
创建绿色社区汇报材料
2014/08/22 职场文书
助学金感谢信
2015/01/20 职场文书
护士长2015年终工作总结
2015/04/24 职场文书
酒店员工手册范本
2015/05/14 职场文书
PHP获取学生成绩的方法
2021/11/17 PHP