前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Bootstrap源码分析之dropdown

Bootstrap源码分析之dropdown

作者头像
sam dragon
发布2018-01-17 10:13:48
2.9K0
发布2018-01-17 10:13:48
举报
文章被收录于专栏:cnblogscnblogs

源码分析:

Dropdowns.scss:下拉框模块 Javascripts/bootstrap/dropdown.js:实现下拉框响应

实现功能及原理:

下拉选项卡,默认不能实现显示选中项的功能

原理:

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

源码分析:

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

代码语言:javascript
复制

 <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注入事件实现的,代码如下:

代码语言:js
复制

$(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事件。

代码语言:js
复制

 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”:是为了实现单击,展开指定的下拉列表,默认是展开与按钮后面兄弟节点:

代码语言:js
复制

 <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、应用示例

代码语言:js
复制

<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>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-05-21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 源码分析:
    • 实现功能及原理:
      • 源码分析:
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档