当前位置: 移动技术网 > IT编程>开发语言>JavaScript > JS沙箱模式实例分析

JS沙箱模式实例分析

2017年12月12日  | 移动技术网IT编程  | 我要评论
本文实例讲述了js沙箱模式。分享给大家供大家参考,具体如下: //sandbox(['module1,module2'],function(box){}); /

本文实例讲述了js沙箱模式。分享给大家供大家参考,具体如下:

//sandbox(['module1,module2'],function(box){});
/*
*
*
* @function
* @constructor
* @param []  array   模块名数组
* @param callback function 回调函数
* 功能:新建一块可用于模块运行的环境(沙箱),自己的代码放在回调函数里,且不会对其他的个人沙箱造成影响
和js模块模式配合的天衣无缝
*
* */
function sandbox() {
  //私有的变量
  var args = array.prototype.slice.call(arguments),
      callback = args.pop(),
      //模块可以作为一个数组传递,或作为单独的参数传递
      modules = (args && typeof args[0] == "string") ? args : args[0];
  //确保该函数作为构造函数调用
  if (!(this instanceof sandbox)) {
    return new sandbox(modules,callback);
  }
  //不指定模块名和“*”都表示“使用所有模块”
  if (!modules || modules[0] === "*") {
    for(value in sandbox.modules){
      modules.push(value);
    }
  }
  //初始化所需要的模块(将想要的模块方法添加到box对象上)
    for (var i = 0; i < modules.length; i++) {
      sandbox.modules[modules[i]](this);
    }
  //自己的代码写在回调函数里,this就是拥有指定模块功能的box对象
  callback(this);
}
 sandbox.prototype={
   name:"my application",
   version:"1.0",
   getname:function() {
     return this.name;
   }
 };
/*
* 预定义的模块
*
* */
sandbox.modules={};
sandbox.modules.event=function(box){
  //私有属性
  var xx="xxx";
  //公共方法
  box.attachevent=function(){
    console.log("modules:event------api:attachevent")
  };
  box.dettachevent=function(){
  };
}
sandbox.modules.ajax=function(box) {
  var xx = "xxx";
  box.makerequest = function () {
  };
  box.getresponse = function () {
  };
}
sandbox(['event','ajax'],function(box){
  box.attachevent();
})

运行效果截图:

更多关于javascript相关内容可查看本站专题:《javascript面向对象入门教程》、《javascript中json操作技巧总结》、《javascript切换特效与技巧总结》、《javascript查找算法技巧总结》、《javascript动画特效与技巧汇总》、《javascript错误与调试技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》及《javascript数学运算用法总结

希望本文所述对大家javascript程序设计有所帮助。

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网