jquery对象之间做 || 运算 ,返回的为什么不是boolean类型

发布于 2022-09-04 21:27:04 字数 337 浏览 12 评论 0

jquery源码片段如下:

        // HANDLE: $(expr, $(...))
        } else if ( !context || context.jquery ) {
            return ( context || rootjQuery ).find( selector );

我认为context这里是一个jquery对象, rootjquery是$(document)

但他们返回的记过不应该是布尔值吗, 这里为什么是一个jquery对象.

所以||运算在这里做了什么? 他的作用是什么???

谢谢

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

云淡月浅 2022-09-11 21:27:04

基础请看这里, 一目了然.
https://developer.mozilla.org...

多说一句, 在 ES2015 以前, JS 的函数是没有默认参数的.
为了像其他语言一样能用默认参数, 经常会这么写

function demo(arg){
    arg = arg || true;
}

还有为了兼容不同浏览器 API 的时候, 也经常这么写.

if( !window.requestAnimationFrame ){
    window.requestAnimationFrame = (window.webkitRequestAnimationFrame ||
                                    window.mozRequestAnimationFrame ||
                                    window.msRequestAnimationFrame || 
                                    function (callback){
                                      return setTimeout(callback, 1000 / 60);
                                    });
}
裸钻 2022-09-11 21:27:04

Javascript逻辑运算符可以在非Boolean的环境中使用.

尽管 && 和 || 运算符能够在非Boolean环境中使用, 但如果他们的返回值能够转换成Boolean值的话,也可以认为是Boolean运算

(来自逻辑运算符)

对于非Boolean的环境中:

当有一个false时,返回false一侧的值
当有两个false时,返回运算符之前(左侧)的值;
当有两个true时,返回运算符之后(右侧)的值。

(来源于JavaScript中的逻辑运算的返回值(逻辑与&&,逻辑或||,逻辑非!))

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文