- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设您想为页面上的许多链接添加 ajax 功能。
<a href='http://domain/purchase/car' class='purchase'>Car</a>
<a href='http://domain/purchase/bag' class='purchase'>Bag</a>
<a href='http://domain/purchase/laptop' class='purchase'>Laptop</a>
和
<a href='http://domain/sell/car' class='sell'>Car</a>
<a href='http://domain/sell/bag' class='sell'>Bag</a>
<a href='http://domain/sell/laptop' class='sell'>Laptop</a>
现在您可以在 JavaScript 代码中定义一些变量来引用这些链接组:
var purchaseLinks = $('.purchase'),
sellLinks= $('.sell');
好了,故事讲够了 ;)。
根据 jQuery's add() documentation ,返回值是一个新的 jQuery 对象。同样,AMAIK 在附加到 jQuery 对象事件的函数处理程序中,this
引用 DOM 元素。
为什么使用add()
方法,handler函数的this
引用了document
?我不明白。我无法根据我的知识做出合乎逻辑的感知。换句话说:
jQueryObject1.click(function(){
// Here, $(this) is the jQuery object
});
jQueryObject2.click(function(){
// Here again, $(this) is the jQuery object
});
jQueryObject1.add(jQueryObject2).click(function(){
// Here $(this) refers to the Document, why?
// I think jQueryObject1.add(jQueryObject2) should equal jQueryObject3
});
更新:
感谢您的回答。我再次向读者推荐 Live is Deprecated页面,以便每个人都可以改进。
最佳答案
您的 fiddle 中的问题是 .live()
的使用。 jQuery 文档状态:
Chaining methods is not supported. For example,
$("a").find(".offsite,
is not valid and does not work as expected.
.external").live( ... );
幸运的是,.live()
method is deprecated ,所以你不必再担心这样的事情了。您可以改用 on
并利用事件委托(delegate)。
更新(根据@Esailija 的评论)
这就是实际发生的事情。你在这里调用 jQuery:
var purchaseLinks = $('.purchase');
这会产生一个 jQuery 对象,它有一个 selector
属性。然后调用 .add()
,后者又调用内部 pushStack
方法:
return this.pushStack(isDisconnected(set[0]) || isDisconnected(all[0]) ? all : jQuery.unique(all));
pushStack
method创建新的 jQuery 对象。它只用一个参数调用。下面是方法的相关部分(注意 name
和 selector
在我们的例子中都是 undefined
):
function (elems, name, selector) {
// ...
ret.context = this.context;
if (name === "find") {
ret.selector = this.selector + (this.selector ? " " : "") + selector;
} else if (name) {
ret.selector = this.selector + "." + name + "(" + selector + ")";
}
// Return the newly-formed element set
return ret;
}
另请注意,this.context
现在是文档(因为您的原始 jQuery 对象未指定上下文,因此假定最高可能的上下文)。
因此新形成的元素集没有selector
属性,并且以文档作为其上下文。当我们调用 .live()
时,jQuery 会像这样调用 .on()
:
jQuery( this.context ).on( types, this.selector, data, fn );
我们可以看到问题所在。上下文是文档,没有选择器,所以事件处理程序被绑定(bind)到文档。在我们的例子中,上面一行实际上是这样的:
jQuery( document ).on( "click", function() {
//Your event handler
});
您可以通过以下事实看到这一点:您的 alert
是通过单击文档中的任意位置而不仅仅是链接触发的。
故事的寓意?停止使用 .live()
!
关于javascript - 为什么 jQuery add() 方法似乎不返回 jQuery 对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11431980/
I have a question about adding files in git. I have found multiple stackoverflow questions about
我是 visual studio 的新手,来自 Delphi。 我有一个充满 .cs 文件的目录树(根是\Common)。 我还有一个充满应用程序的目录树(根目录是\Applications) 最后,
这个问题在这里已经有了答案: Array's lookup time complexity vs. how it is stored (4 个答案) Time complexity for java
谁能告诉我这两者有什么区别: ALTER TABLE x1 ADD INDEX(a); ALTER TABLE x1 ADD INDEX(b); 和 ALTER TABLE x1 ADD INDEX(
为什么有时我们使用 getChildren() add() 而其他时候我们直接使用 add() es: https://docs.oracle.com/javafx/2/get_started/for
如何使用 bootstrap css 在输入下方添加跨度?我需要做这样的事情: 最佳答案 是这样的吗? http://jsfiddle.net/swm53ran/205/ 您可以使用纯 CSS 来实现
问题 np.add(X, 2*Y, out=X) 比 np.add(X, Y, out=X); np.add(X, Y, out=X).使用 np.add(X, Y, out=X); 是一种实际做法吗
当我跑 git add --intent-to-add .所有未跟踪的文件将其状态从“未跟踪的文件”( git status -s 显示 ?? )更改为“未暂存以进行提交的更改”( git statu
我不知道 .add 之间有什么区别和 .sink.add ? 例子: StreamController myStreamController = StreamController(); stream
getContentPane().add() 和 add() 的意思一样吗? public class TestFrame extends JFrame{ public TestFrame()
git add . 和 git add * 会完成完全相同的事情吗? 最佳答案 不,不会。 * 是一个 glob 模式,不会匹配以 开头的文件。 例如,假设这是当前目录,我有 2 个新文件要添加 fo
git的分支与合并的两种方法 git add -A和 git add . git add -u在功能上看似很相近,但还是存在一点差别 git add . :他会
git add [--all | -A] 之间有什么区别?和 git add . ? 最佳答案 此答案仅适用于 Git 版本 1.x。对于 Git 版本 2.x,请参阅其他答案。 总结: git ad
我刚刚安装了最新的 Wix v3.7。我创建了一个 VS 2010“Excel 2010 加载项”项目,并在同一个解决方案中创建了一个 Wix“安装项目”。 问题是,当我尝试从 Wix 项目中引用 A
YUI.add 和 YUI().add 有什么区别? 最佳答案 在第一种情况下,您要注册一个模块可以加载到 YUI 沙箱中,在第二种情况下,您要构建一个沙箱,然后进行注册(这是一种非常不典型的用法)。
测试代码时,任何输入到列表中的值在按下“enter”后都会消失。 我对编程和网络开发非常陌生。请具体一点,以便我理解。 function addItem(){ var item = documen
我正在浏览 python 的 dis 包。我尝试了代码以查看它是如何工作的 >>> def get(): ... x=4 ... y=x+3 ............ this lin
我已经对我的文件夹进行了版本控制 git init git add . git commit -m 'Initial commit' 我应该怎么做 git add 对于我在 .? 中创建的每个新文件
当我执行 $ git add * 时,有时我意识到 git 不会将已删除的文件添加到舞台上,如果删除或添加它,我需要手动指示,但我想不通找出 $ git add --all 有什么区别。因此,如果星号
这个问题在这里已经有了答案: Difference between "git add -A" and "git add ." (12 个答案) 关闭 6 年前。 目前,当我想提交并将内容推送到远程
我是一名优秀的程序员,十分优秀!