search

Home  >  Q&A  >  body text

javascript - 为何很多jquery插件都要这么写

如题,我发现很多插件都是如下风格的代码

(function ($) {
    $.fn.xxxx = ....
})(jQuery);

为什么不直接

$.fn.xxxx = ....
巴扎黑巴扎黑2901 days ago409

reply all(3)I'll reply

  • 黄舟

    黄舟2017-04-10 14:45:00

    主要原因是你不能保证$就是jQuery对象,因为$有可能被其他库占用,或被重新定义,或者执行了jQuery.noConfict()等。但是jQuery这个对象肯定是存在的。所以保险起见,要加一个匿名的闭包将jQuery对象作为参数传进去,以确保$ === jQuery

    不光是写插件的时候要这么做,在写其他代码时,也很有必要这样。

    reply
    0
  • PHPz

    PHPz2017-04-10 14:45:00

    (function ($) {
    $.fn.xxxx = ....
    })(jQuery);
    这叫做匿名函数自调用,这样做的好处是避免将变量暴露到全局变量中去。前面说到冲突的问题,在实际的项目中,大部分主要还是jq为主,应该很少碰到jq和其他框架共存的项目,除了prototype也会用到$,其他的框架没使用这个变量。

    reply
    0
  • 怪我咯

    怪我咯2017-04-10 14:45:00

    更高大上,

    (function ($) {
    $.fn.xxxx = ....
    })(jQuery);

    这种写法$不会与别的框架冲突,
    后面写法会和其他框架中的$冲突。

    reply
    0
  • Cancelreply