首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >有人能解释一下定义jQuery插件时的语法含义吗?

有人能解释一下定义jQuery插件时的语法含义吗?
EN

Stack Overflow用户
提问于 2010-06-05 00:39:57
回答 3查看 237关注 0票数 0

我正在阅读有关创建自定义jQuery插件的内容,并且对以下语法的含义感到有点困惑:

代码语言:javascript
复制
(function($){  
    $.fn.truncate = function() {  
        return this.each(function() { 
        });
     };
})(jQuery);

我知道函数( $ )是一个接受$的匿名函数。我只是不太明白为什么这个函数被括在方括号中,以及下面的几组方括号是如何在them...work中使用jQuery的。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-06-05 00:56:04

假设jQuery库拥有$是不安全的。一些其他javascript库/用户可以/确实将该标识符用于其他目的。但是,jQuery始终是jQuery库(不包括任何作恶者)。

这个匿名函数将$快捷方式安全地公开为jQuery,方法是将其设置为匿名函数的本地参数。由于参数仅在函数作用域内覆盖任何全局变量,因此这不会影响函数外部的任何其他用户/库代码。

最后,在执行匿名函数的地方,将传入jQuery作为填充$的第一个参数。

因此,归根结底,这只是插件开发人员为安全可靠地使用$而采取的一条捷径;如果您不介意在任何地方使用jQuery,那么这完全是可选的。

票数 3
EN

Stack Overflow用户

发布于 2010-06-05 00:46:38

jQuery的以下参数只是执行匿名函数,并将jQuery作为$参数传入。这确保了$= jQuery只是在incase window.$不等于jQuery。

以下是代码的重写,可能更有意义:

代码语言:javascript
复制
function myFunc($) {   
 $.fn.truncate = function() {   
    return this.each(function() {   
 });   
}

myFunc(jQuery);
票数 5
EN

Stack Overflow用户

发布于 2010-06-05 00:45:24

圆括号创建了一个匿名函数,$元件将全局jQuery对象引用到该函数。

$.fn.truncate -这意味着您正在扩展jQuery对象以包含一个名为truncate的新函数。

Usage $( '#someElement' ).truncate();

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2976089

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档