/* ========================================================================
* Bootstrap: collapse.js v3.3.7
* http://getbootstrap.com/javascript/#collapse
* ========================================================================
* Copyright 2011-2016 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
* ======================================================================== */ /* jshint latedef: false */ +function ($) {
'use strict'; // COLLAPSE PUBLIC CLASS DEFINITION
// ================================ var Collapse = function (element, options) {
this.$element = $(element)
this.options = $.extend({}, Collapse.DEFAULTS, options)
this.$trigger = $('[data-toggle="collapse"][href="#' + element.id + '"],' +//这是一个复合选择器 href data-target双保险
'[data-toggle="collapse"][data-target="#' + element.id + '"]')
this.transitioning = null if (this.options.parent) {
this.$parent = this.getParent()//不仅返回了父元素而且还还把子元素的状态做了标记,比如谁是打开的。。。
} else {
this.addAriaAndCollapsedClass(this.$element, this.$trigger)
} if (this.options.toggle) this.toggle()
} Collapse.VERSION = '3.3.7' Collapse.TRANSITION_DURATION = 350 Collapse.DEFAULTS = {
toggle: true
} Collapse.prototype.dimension = function () {
var hasWidth = this.$element.hasClass('width')
return hasWidth ? 'width' : 'height'
} Collapse.prototype.show = function () {
if (this.transitioning || this.$element.hasClass('in')) return var activesData
var actives = this.$parent && this.$parent.children('.panel').children('.in, .collapsing')//得到active的 if (actives && actives.length) {
activesData = actives.data('bs.collapse')
if (activesData && activesData.transitioning) return
} var startEvent = $.Event('show.bs.collapse')//在这里触发这个事件 (未显示之前)
this.$element.trigger(startEvent)
if (startEvent.isDefaultPrevented()) return if (actives && actives.length) {
Plugin.call(actives, 'hide')//隐藏
activesData || actives.data('bs.collapse', null)//activesData 没有的话,,,就设为null ????
} var dimension = this.dimension() this.$element
.removeClass('collapse')
.addClass('collapsing')[dimension](0)
.attr('aria-expanded', true) this.$trigger
.removeClass('collapsed')
.attr('aria-expanded', true) this.transitioning = 1 var complete = function () {
this.$element
.removeClass('collapsing')
.addClass('collapse in')[dimension]('')
this.transitioning = 0
this.$element
.trigger('shown.bs.collapse')
} if (!$.support.transition) return complete.call(this) var scrollSize = $.camelCase(['scroll', dimension].join('-')) this.$element
.one('bsTransitionEnd', $.proxy(complete, this))
.emulateTransitionEnd(Collapse.TRANSITION_DURATION)[dimension](this.$element[0][scrollSize])//在最后通过取scrollHeight值,设置height(因为已经设置了css过度,)这里才是真正核心的功能,得到了隐藏元素的高度scrollHeight
} Collapse.prototype.hide = function () {
if (this.transitioning || !this.$element.hasClass('in')) return var startEvent = $.Event('hide.bs.collapse')
this.$element.trigger(startEvent)
if (startEvent.isDefaultPrevented()) return var dimension = this.dimension() this.$element[dimension](this.$element[dimension]())[0].offsetHeight//在style里面设置高度(为过度需要) this.$element
.addClass('collapsing')//添加css过度类
.removeClass('collapse in')
.attr('aria-expanded', false) this.$trigger
.addClass('collapsed')
.attr('aria-expanded', false) this.transitioning = 1 var complete = function () {//完成后调用的方法,处理收尾工作,1:把没有用的去掉,2:触发hidden.bs.collapse(隐藏后回调事件) 感觉很科学的样子
this.transitioning = 0
this.$element
.removeClass('collapsing')
.addClass('collapse')
.trigger('hidden.bs.collapse')
} if (!$.support.transition) return complete.call(this) this.$element
[dimension](0)//style里面的height设置为0,触发过度效果
.one('bsTransitionEnd', $.proxy(complete, this))
.emulateTransitionEnd(Collapse.TRANSITION_DURATION)
} Collapse.prototype.toggle = function () {
this[this.$element.hasClass('in') ? 'hide' : 'show']()//toggle做的很地道啊
} Collapse.prototype.getParent = function () {
return $(this.options.parent)
.find('[data-toggle="collapse"][data-parent="' + this.options.parent + '"]')//获取子元素
.each($.proxy(function (i, element) {//对子元素进行。。。。
var $element = $(element)
this.addAriaAndCollapsedClass(getTargetFromTrigger($element), $element)
}, this))
.end()
} Collapse.prototype.addAriaAndCollapsedClass = function ($element, $trigger) {//0:靶子元素,1:触发的元素(a)
var isOpen = $element.hasClass('in') $element.attr('aria-expanded', isOpen)//expanded(扩大的,expand的过去式和过去分词) 记号
$trigger
.toggleClass('collapsed', !isOpen)
.attr('aria-expanded', isOpen)
} function getTargetFromTrigger($trigger) {//获取靶子元素
var href
var target = $trigger.attr('data-target')
|| (href = $trigger.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') // strip for ie7 #号前面的东西替换成''. return $(target)
} // COLLAPSE PLUGIN DEFINITION
// ========================== function Plugin(option) {
return this.each(function () {
var $this = $(this)
var data = $this.data('bs.collapse')
var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option) if (!data && options.toggle && /show|hide/.test(option)) options.toggle = false
if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
if (typeof option == 'string') data[option]()
})
} var old = $.fn.collapse $.fn.collapse = Plugin
$.fn.collapse.Constructor = Collapse // COLLAPSE NO CONFLICT
// ==================== $.fn.collapse.noConflict = function () {
$.fn.collapse = old
return this
} // COLLAPSE DATA-API
// ================= $(document).on('click.bs.collapse.data-api', '[data-toggle="collapse"]', function (e) {
var $this = $(this) if (!$this.attr('data-target')) e.preventDefault() var $target = getTargetFromTrigger($this)//
var data = $target.data('bs.collapse')
var option = data ? 'toggle' : $this.data() Plugin.call($target, option)
})
/**$('[data-toggle="collapse"]').collapse('toggle');**/ }(jQuery);

bootrap 手风琴Collapse源码分析的更多相关文章

  1. antd源码分析之——折叠面板(collapse)

    官方文档 https://ant.design/components/collapse-cn/ 目录 一.antd中的collapse 代码目录 1.组件结构图(♦♦♦重要) 2.源码节选:antd/ ...

  2. cocos2dx骨骼动画Armature源码分析(一)

    源码分析一body { font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height: 1.6; padding-to ...

  3. element-ui 组件源码分析整理笔记目录

    element-ui button组件 radio组件源码分析整理笔记(一) element-ui switch组件源码分析整理笔记(二) element-ui inputNumber.Card .B ...

  4. Bootstrap源码分析系列之初始化和依赖项

    在上一节中我们介绍了Bootstrap整体架构,本节我们将介绍Bootstrap框架第二部分初始化及依赖项,这部分内容位于源码的第8~885行,打开源码这部分内容似乎也不是很难理解.但是请站在一个开发 ...

  5. Bootstrap导航栏navbar源码分析

    1.本文目地:分析bootstrap导航栏及其响应式的实现方式,提升自身css水平 先贴一个bootstrap的导航栏模板 http://v3.bootcss.com/examples/navbar- ...

  6. ThreeJS 物理材质shader源码分析(顶点着色器)

    再此之前推荐一款GLTF物理材质在线编辑器https://tinygltf.xyz/ ThreeJS 物理材质shader源码分析(顶点着色器) Threejs将shader代码分为ShaderLib ...

  7. ABP源码分析一:整体项目结构及目录

    ABP是一套非常优秀的web应用程序架构,适合用来搭建集中式架构的web应用程序. 整个Abp的Infrastructure是以Abp这个package为核心模块(core)+15个模块(module ...

  8. HashMap与TreeMap源码分析

    1. 引言     在红黑树--算法导论(15)中学习了红黑树的原理.本来打算自己来试着实现一下,然而在看了JDK(1.8.0)TreeMap的源码后恍然发现原来它就是利用红黑树实现的(很惭愧学了Ja ...

  9. nginx源码分析之网络初始化

    nginx作为一个高性能的HTTP服务器,网络的处理是其核心,了解网络的初始化有助于加深对nginx网络处理的了解,本文主要通过nginx的源代码来分析其网络初始化. 从配置文件中读取初始化信息 与网 ...

随机推荐

  1. weblogic启动 web应用ssh关闭 nohup命令

    平时我们操作linux服务器的时候,都是通过ssh远程连接,然后启动服务器上的服务的,所以有时候启动weblogic,我们关闭ssh,weblogic 服务也相应的关闭了,那么我们就只能用nohup这 ...

  2. Java核心技术卷1 第三章

    1. Java区分大小写,下一段源代码中,关键字public称为访问修饰符,用于控制程序的其他部分对于这段代码的访问级别,关键字class表明Java程序中的全部内容都包含在类里面. 标准的类名命名规 ...

  3. 远程连接mysql数据库

    远程连接mysql数据库需要以下步骤(改表法): 1.数据源(数据库服务器)对要访问数据库进行授权: 2.本地库(本地)连接: 具体方法: 1. 进入数据服务器,输入cmd进入控制台:输入 mysql ...

  4. Buffer.concat()

    Buffer.concat(list[, totalLength]) Node.js FS模块方法速查 list {Array} 需要连接的 Buffer 对象数组 totalLength {Numb ...

  5. Quartz --Scheduler

  6. GPIO——端口位设置/清除寄存器BSRR,端口位清除寄存器BRR

    端口位设置/复位寄存器BSRR: 注:如果同时设置了BSy和BRy的对应位,BSy位起作用. 位31:16  BRy: 清除端口x的位y (y = 0…15)      这些位只能写入并只能以字(16 ...

  7. 添物不花钱学JavaEE(基础篇) --HTML

    HTML是什么? HTML – Hyper Text Markup Language HTML官方网址 http://www.w3.org/TR/2014/REC-html5-20141028/ 其实 ...

  8. DD & E-app

    DD & E-app 企业内部开发的E应用 前端 demo https://github.com/open-dingtalk docs https://open-doc.dingtalk.co ...

  9. POJ1094 / ZOJ1060

    #include <cstdio> #include <cstring> #include <stack> #include <iostream> us ...

  10. [luoguP1972] [SDOI2009]HH的项链(莫队 || 树状数组 || 主席树)

    传送门 莫队基础题,适合我这种初学者. 莫队是离线算法,通常不带修改,时间复杂度为 O(n√n) 我们要先保证通过 [ l , r ] 求得 [ l , r + 1 ] , [ l , r - 1 ] ...