VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > 网站开发 > JavaScript >
  • JavaScript教程之

可以利用js中函数的闭包进行封装

通常我们可以用下面这种方法进行一个封装,这样在外部引入我们写的这个js文件后,就可以直接使用export.getUserId()这种形式去调用该函数

复制代码
(function($, owner) {
    /*
     * 中间就可以进行封装操作
     * $就代表mui,owner就代表window的export属性,就是一个传值
     */
    var _userId = 1;
    function converter(userId){
        return +userId;
    }
    owner.getUserId = function(){
        return converter(_userId);
    }
}(mui, window.export = {}));
复制代码

上面写法等价于下面这一种,下面可能更易于理解,但都差不多,这样就进行了封装
然后在其他地方就可以通过window的全局对象来调用(直接用对象名即可),如:
export.getUserId() //得到的值就是1


因为函数有函数的作用域,所以函数内部定义的变量外部是无法访问的,那么要想外部访问到怎么办呢?
这里可以通过定义一个export对象,将这个对象输出出去(输出到window的export对象)
这样外部就能拿到这个对象里定义的变量(方法)

复制代码
(function(){
    var _userId = 1;
    var export = {};
    function converter(userId){
        return +userId;
    }
    export.getUserId = function(){
        return converter(_userId);
    }
    window.export = export;
}());
复制代码

这里如果直接用export._userId,是拿不到这个属性的,除非你定义为export._userId,这样就可以,


相关教程