今天做的项目,用到了bootstrap的折叠功能,这个功能需要只展开一个折叠框,点击一个就会自动隐藏另一个,初始按照API做了一下,发现一切运行正常,但是测试的同事提了一个bug,说切换到其他模块后再切换回来,发现原先展开的折叠框没有折叠起来--即恢复原样。于是又去修改代码,回来的时候对所有折叠框调用: .collapse('hide')方法。
$(".love .collapse").collapse('hide');
调用之后发现,点击连接苗,data-parent失效了,也就是可以同时展开多个折叠框
这严重脱离了需求,于是又去查了API并写了几个demo,发现了一个问题,只要在初始化的时候调用 .collapse()方法,就会出现这种同时展开多个折叠框的情况。但是奇怪的是:当页面渲染出来后,你去点击了折叠框后,这个时候再触发某个事件调用.collapse()方法,就不会出现这种同时展开多个的情况。
于是找到了两个解决的方法:
方法一:
在我的项目中,折叠框默认是折叠的,即没有.in类,基于以上的发现,于是改变源码:
$(".love .collapse.in").collapse('hide');
因为在bootstrap中折叠框的展开是由.in类修饰的,所以有.in类的必定是经过点击的,在初始化的时候
$(".love .collapse.in")
返回的必定是[]数组,因为默认是收起的。经过几个浏览器的测试,发现没有问题,问题解决了。
方法二:
在一个外国网站也发现了一个解决的方法,触发这种事件发生的原因是bootstrap的js的某个机制的实现问题,但是API没有给出这种事件的说明和处理方法,于是我们可以重写折叠框展开和收起的事件,首先在连接处加一个类.collapse-toggle,这个类可以随便指定.:
$(document).on('click', '.collapse-toggle', function(event) {
event.stopPropagation();
var $this = $(this);
var parent = $this.data('parent');
var actives = parent && $(parent).find('.collapse.in');
// From bootstrap itself
if (actives && actives.length) {
hasData = actives.data('collapse');
//if (hasData && hasData.transitioning) return;
actives.collapse('hide');
}
var target = $this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, ''); //strip for ie7
$(target).collapse('toggle');
});
这里用到了jQuery的data()方法,data()方法可以获取标签的data-*属性,我认为用在这里不是很好,主要是这个方法在IE6、IE7中不支持,要想完美兼容,可以使用attr()方法。
以上所述是小编给大家介绍的bootstrap折叠调用collapse()后data-parent不生效的快速解决办法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# bootstrap
# collapse
# vue组件 $children
# $refs
# $parent的使用详解
# PHP面向对象学习之parent::关键字
# PHP中子类重载父类的方法【parent::方法名】
# php实现parent调用父类的构造方法与被覆写的方法
# getcwd cannot access parent directories错误解决方法
# springboot实现拦截器之验证登录示例
# Springboot使用POI实现导出Excel文件示例
# 详解SpringBoot文件上传下载和多文件上传(图文)
# SpringBoot定时任务两种(Spring Schedule 与 Quartz 整合 )实现方法
# 详解Spring Boot 项目中的 parent
# 多个
# 几个
# 就会
# 小编
# 又去
# 的是
# 发现了
# 很好
# 在此
# 是由
# 我们可以
# 我认为
# 要想
# 给大家
# 你去
# 写了
# 这个时候
# 重写
# 可以使用
# 一个问题
相关文章:
如何在Windows服务器上快速搭建网站?
非常酷的网站设计制作软件,酷培ai教育官方网站?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
利用JavaScript实现拖拽改变元素大小
如何在阿里云通过域名搭建网站?
香港服务器部署网站为何提示未备案?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
如何用IIS7快速搭建并优化网站站点?
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
已有域名和空间如何搭建网站?
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
如何通过多用户协作模板快速搭建高效企业网站?
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
如何用西部建站助手快速创建专业网站?
网站制作报价单模板图片,小松挖机官方网站报价?
如何用搬瓦工VPS快速搭建个人网站?
如何快速搭建个人网站并优化SEO?
如何正确下载安装西数主机建站助手?
活动邀请函制作网站有哪些,活动邀请函文案?
如何快速搭建高效可靠的建站解决方案?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
外贸公司网站制作哪家好,maersk船公司官网?
定制建站策划方案_专业建站与网站建设方案一站式指南
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
网站网页制作专业公司,怎样制作自己的网页?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
html制作网站的步骤有哪些,iapp如何添加网页?
视频网站app制作软件,有什么好的视频聊天网站或者软件?
如何快速搭建高效香港服务器网站?
上海网站制作网站建设公司,建筑电工证网上查询系统入口?
已有域名和空间,如何快速搭建网站?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
制作证书网站有哪些,全国城建培训中心证书查询官网?
一键网站制作软件,义乌购一件代发流程?
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
西安大型网站制作公司,西安招聘网站最好的是哪个?
孙琪峥织梦建站教程如何优化数据库安全?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
专业商城网站制作公司有哪些,pi商城官网是哪个?
独立制作一个网站多少钱,建立网站需要花多少钱?
如何确保FTP站点访问权限与数据传输安全?
如何通过cPanel快速搭建网站?
建站之星安装需要哪些步骤及注意事项?
如何在云指建站中生成FTP站点?
如何零基础开发自助建站系统?完整教程解析
c# 在高并发下使用反射发射(Reflection.Emit)的性能
*请认真填写需求信息,我们会在24小时内与您取得联系。