基本概念
1、沙箱:与外界隔绝的一个环境,外界无法修改该环境内任何信息,沙箱内的东西单独属于一个世界
2、苹果手的app使用的就是沙箱模式去运行,隔离app的空间,每个app独立运行
js沙箱基本模式
1、在沙箱中将所有变量的定义放在最上方
2、中间就放一些逻辑代码
3、最后,如果需要,就给外界暴露一些成员(通过window.的方式,给window添加属性)
<script> ???(function(){ ???????var sum = 0; ???????for(var i = 1; i<=100;i++){ ???????????sum+=i; ???????} ???????console.log(sum);//5050 ???})();</script>
为什么要用立即调用的方式
1、因为不会再外界暴露任何的全局变量,但是又可以形成一个封闭的空间
jQuery当中的沙箱模式
1、如果需要在外界暴露一些属性或者方法,就可以将这些属性和方法加到window全局对象上去
2、window全局对象不可以直接引用,因为直接引用会破坏沙箱原则,可以选择使用传参的形式将 window对象 传入沙箱内
3、此时沙箱内使用window对象的时候,不会再去全局搜索window对象,而使用的就是沙箱内部定义的形参
<script> ???(function(win){ ???????var itcast = { ???????????getEle:function () { ???????????} ???????} ???????win.itCast = win.$ = itcast; ???})(window)</script>
JS高级——沙箱
原文地址:https://www.cnblogs.com/wuqiuxue/p/8342711.html