2

用 jQuery 包装两次 HTML 元素是一种安全的操作,因为它返回相同 DOM 元素的实例:

var $a = $('#foo');
var $b = $($a);
alert($b.get(0) === $a.get(0)); // true

它允许灵活设置配置对象,这些对象可能包含选择器、DOM 元素或 jQuery 实例。

我不知道,所以在我的个人库中,我使用方法扩展了 jQuery,以安全地包装和解开对象。

jQuery 核心中是否有一个安全的向后操作来从它们的相关 jQuery 实例中解开 DOM 元素?

我的意思是这样的事情:

function unwrap(obj) {
    return (obj instanceof jQuery) ? obj.get(0) : obj;
}

这足够聪明,可以避免每次都有条件检查。

4

2 回答 2

1

将所有内容包装在 jQuery 中然后从结果数组中获取第 0 个元素会更有意义:

jQuery( elem )[0];

如果传递一个 jQuery 对象,jQuery( jQueryObject )将以相同的顺序返回相同的元素。如果您传递一个元素,则返回该元素。如果您传递一个 jQuery 对象,这将返回其中的第一个元素。如果你传递一个选择器,这将返回 DOM 中的第一个匹配项。

我们在 jQuery UI 中使用类似的技术来基本上解析您在选项中传递给小部件的任何选择器/元素/jquery 对象。

于 2013-01-15T17:37:56.740 回答
1

Detect DOM object vs. jQuery Object似乎包含了这个问题的答案。

每个 jQuery 对象都有一个 jquery 属性。就像是:

function unwrap(obj) {
    return (obj.jquery) ? obj.get(0) : obj;
}
于 2013-01-15T17:26:24.440 回答