在jQuery范围内访问函数

时间:2014-06-27 10:02:24

标签: javascript jquery

我想在jQuery范围之外构建一个函数:

(function($) {
  function MyObject() {
    console.log('foo');
  };
}(jQuery));
var $my_object = new MyObject();

但是无法访问函数MyObject:

  

ReferenceError:未定义MyObject

但是,如果我在范围内构建我的函数,它正在工作:

(function($) {
  function MyObject() {
    console.log('foo');
  };
  var $my_object = new MyObject();    
}(jQuery));
  

FOO

如何访问范围之外的MyObject?

2 个答案:

答案 0 :(得分:0)

我可能不会推荐它,但你基本上可以通过将函数作为对象的一部分返回并将IIFE分配给这样的变量来完成你想要的工作

var library = (function ($) {

    var exports = {};
    var private = 'see you cant get this';
    var MyObject = exports.MyObject = function (_in) {
        console.log(_in);
    };
    var another_func = exports.sum = function (a, b) {
        console.log(a + b);
    };


    return exports;
}(jQuery));



library.MyObject('foobar'); // "foobar"
library.sum(3, 5);  // 8
console.log(private);  // Uncaught ReferenceError: private is not defined

答案 1 :(得分:0)

虽然我不知道你为什么要这样做..也许这有帮助

// Define Class globally
// window.MyObject also works
var MyObject = (function($) {
// Passes jQuery in
  return function () {
    console.log('foo');
  };

}(jQuery));
var $my_object = new MyObject();