- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我使用您页面上演示中有效的标记为 Twitter Bootstrap 的折叠功能创建了一个 fiddle :http://jsfiddle.net/Rymd7/1/
然后有一次,我添加了对 prototypejs 折叠功能的引用,在单击几次后停止在每个 Accordion 组上工作。 http://jsfiddle.net/p5SAy/1/我不确定问题是什么或如何纠正。
这是 Bootstrap 问题还是有办法解决这个问题并让这两个 js 库存在于同一页面上?
我已经尝试过 jQuery noConflict 但没有成功,但我们将不胜感激。如果您能给我寄回一个可以正常工作的 fiddle ,那就太好了……或者任何见解。
谢谢。 -约翰
最佳答案
您正在同时使用 jQuery 和 Prototype 而没有 jQuery.noConflict()
。之后
<script type='text/javascript' src='http://code.jquery.com/jquery-1.7.js'></script>
<script type='text/javascript' src="http://ajax.googleapis.com/ajax/libs/prototype/1.7.0/prototype.js"></script>
此行导致 javascript 错误:
$(window).load(function(){
修改后的 fiddle :http://fiddle.jshell.net/ymbsr/5/ - 打开 http://fiddle.jshell.net/ymbsr/5/show/在不同的浏览器中。
附言
删除 jQuery/Prototype 冲突后,我可以看到 Chrome 21 和 Opera 12.02 Accordion 过渡永远不会结束(在 bootstrap-collapse.js
Collapse.transition
启动过渡但complete()
永远不会被调用)。 if (this.transitioning) return
后,对同一元素的 Collapse.show()/hide()
的进一步调用将退出。
在 Firefox 15.0.1 中 Accordion 工作正常。
附言
这种奇怪的行为是两个特征的结果:
this.$element.trigger('hide')
(在 Collapse#transition()
中)尝试调用 $element.hide( )
如果元素中存在方法 hide()
- 那就是 by design :
Note: For both plain objects and DOM objects, if a triggered event name matches the name of a property on the object, jQuery will attempt to invoke the property as a method if no event handler calls event.preventDefault(). If this behavior is not desired, use .triggerHandler() instead.
在每个支持HTML元素原型(prototype)扩展的浏览器中使用Prototype $element
肯定会有hide()
方法,它实际上通过设置element.style来隐藏元素。显示 = '无'
。
在当前版本的 Chrome 和 Opera 中,过渡结束事件(webkitTransitionEnd
、oTransitionEnd
、otransitionend
之一)不会触发,如果元素是隐藏的(具有 display: none
样式)。 Firefox 更成功地结束了它的过渡,但也 may not fire event under some circumstances :
Note: The "transitionend" event doesn't fire if the transition is aborted because the animating property's value is changed before the transition is completed.
如何解决:
为 bootstrap-collapse.js
提交错误 - 它不应该 rely only on transition end event
为 bootstrap-collapse.js
提交错误 - 它的 hide
事件与其他框架相交(至少与 Prototype 相交,但任何其他框架扩展元素原型(prototype)可能会受到影响)。
从 bootstrap-collapse.js
中临时修补 Collapse#transition()
,如 http://fiddle.jshell.net/ymbsr/7/ - 禁用事件触发或更改事件名称。
jQuery.fn.collapse.Constructor.prototype.transition = function (method, startEvent, completeEvent) {
var that = this
, complete = function () {
if (startEvent.type == 'show') that.reset();
that.transitioning = 0;
that.$element.trigger(completeEvent);
}
//this.$element.trigger(startEvent);
//if (startEvent.isDefaultPrevented()) return;
this.transitioning = 1;
this.$element[method]('in');
(jQuery.support.transition && this.$element.hasClass('collapse')) ?
this.$element.one(jQuery.support.transition.end, complete) :
complete();
};
关于javascript - Twitter Bootstrap Transition Conflict prototypejs,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12715254/
Postgres 10 和 11 的插入规范说: ON CONFLICT [ conflict_target ] conflict_action 我有一张 table : create table c
我的理解是conflict serializable 隐含serializable。我不确定这如何让他们与众不同。可序列化是否意味着冲突可序列化? 最佳答案 冲突可序列化是可序列化的一个子集,因此仅仅
在数据库理论中,“冲突可序列化”和“冲突等价”有什么区别? 我的教科书有一节是关于冲突可序列化的,但掩盖了冲突等价性。这些可能都是我熟悉的概念,但我不熟悉术语,所以我正在寻找解释。 最佳答案 DBMS
我有一个项目一直在 Xcode 4.4.1 中进行,我想回到以前的分支。(注意分支并不复杂,而是代表线性发展) 当我选择上一个分支时有一个警告 UserInterfaceState.xcusersta
我得到了一个 environment.ubuntu.yml文件,以便能够创建 conda 环境。但是,运行 conda create env --file environment.ubuntu.yml
我浏览了互联网,找不到我的问题的清晰简洁的答案。我想知道如果我将相同强度的信号驱动到同一根电线上会发生什么,其中一个是逻辑 1,另一个是逻辑 0?如果我想要一个“获胜”的信号,因为没有更好的词,我该怎
我在2个网站上有2个不同的图片: http://www.siteA.com/avatar.png http://www.siteB.com/avatar.png 如果我创建具有2个起源的Amazon
我正在 Labview 中开发一个数据采集程序,该程序使用多个转换阶段、相机、高速数字化仪和其他仪器。我正在一台计算机上开发该应用程序,并将其部署到另一台计算机上。开发计算机有labview 2013
能否请您帮助我理解为什么乐观并发更新会有这样的结果。 比如说,我有以下文件: { "phrase": "some phrase", "id": "5d1341797e2ed599", "_
我想安装这两个包: “anahkiasen/前任”:“开发大师” "vespakoen/menu": "dev-master" 但是 composer 说它们每个都依赖于这个包的不同版本: "anah
我在运行 powershell 时遇到以下错误 $thumbprint=$(az webapp config ssl upload --certificate-file $Path --certifi
我不太确定这是否是我使用的 SQLite 版本的问题。但实际上我并没有直接使用 native SQLite (dll),我使用的是 System.Data.SQLite 版本 1.0.108.0 看起
我有一个具有 iBeacon 服务和标准 BLE 服务的芯片。 我想使用 iBeacon 服务在进入 BLE 信号范围时触发我正在开发的应用。 激活后,我希望应用程序使用 CoreBluetooth
建表语句: ? 1
我使用此链接中的示例创建了测试 Telegram 机器人控制台应用程序 https://github.com/TelegramBots/Telegram.Bot.Examples 这是我的主要 pub
我有这个 hpp 文件: struct rte_spinlock_t; class A { public: void init(); private:
我已经从 GitHub 中提取了文件。现在我需要创建一个合并冲突。 如何在 GitHub 上故意创建合并冲突? 最佳答案 在两个分支中编辑同一行,并尝试合并 Merge conflicts in gi
我是这个 repo 的管理员。在这个 PR 中,我删除了多个文件并将这些更改从本地合并到源/开发。将 origin/develop 合并到 origin/master 时,我遇到了我删除的四个文件之一
我使用 Azure 表存储从 MVC 应用程序记录访问者信息,但有时会引发以下异常: [WebException: The remote server returned an error: (409)
我有一张 table : create table c ( e text not null, m text not null, p numeric not null,
我是一名优秀的程序员,十分优秀!