搜尋

首頁  >  問答  >  主體

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

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

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

为什么不直接

$.fn.xxxx = ....
巴扎黑巴扎黑2909 天前411

全部回覆(3)我來回復

  • 黄舟

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

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

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

    回覆
    0
  • PHPz

    PHPz2017-04-10 14:45:00

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

    回覆
    0
  • 怪我咯

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

    更高大上,

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

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

    回覆
    0
  • 取消回覆