JavaScript把局部变量变成全局变量

简介: JavaScript把局部变量变成全局变量

首先我们要知道函数的自调用


函数的自调用——自调用函数


一次性的函数——声明的同时,直接调用了


例如:


(function () {
  console.log("函数");
})();


我们会看到浏览器直接打印 函数 两个字


页面加载后.这个自调用函数的代码就执行完了


使用形式


(function (形参) {
})(实参);


注意


  • 自调用构造函数的方式,分号一定要加上


那么如何把局部变量变成全局变量?


把局部变量给window就可以了


(function (win) {
  var num=10;//局部变量
  //js是一门动态类型的语言,对象没有属性,点了就有了
  win.num=num;
})(window);
console.log(num);


页面打印出num了



应用案例1——将随机数对象赋给window



<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>title</title>
  <script>
     //通过自调用函数产生一个随机数对象,在自调用函数外面,调用该随机数对象方法产生随机数
     (function (window) {
       //产生随机数的构造函数
       function Random() {
       }
       //在原型对象中添加方法
       Random.prototype.getRandom = function (min,max) {
         return Math.floor(Math.random()*(max-min)+min);
       };
       //把Random对象暴露给顶级对象window--->外部可以直接使用这个对象
       window.Random=Random;
     })(window);
     //实例化随机数对象
     var rm=new Random();
     //调用方法产生随机数
     console.log(rm.getRandom(0,5));
    //全局变量
  </script>
</head>
<body>
</body>
</html>


应用案例2——产生随机位置小方块


<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta >
  <title>title</title>
  <style>
    .map{
      width: 800px;
      height: 600px;
      background-color: #CCC;
      position: relative;
    }
  </style>
</head>
<body>
<div class="map"></div>
<script src="common.js"></script>
<script>
  //产生随机数对象的
  (function (window) {
    function Random() {
    }
    Random.prototype.getRandom=function (min,max) {
      return Math.floor(Math.random()*(max-min)+min);
    };
    //把局部对象暴露给window顶级对象,就成了全局的对象
    window.Random=new Random();
  })(window);//自调用构造函数的方式,分号一定要加上
  //产生小方块对象
  (function (window) {
    //console.log(Random.getRandom(0,5));
    //选择器的方式来获取元素对象
    var map=document.querySelector(".map");
    //食物的构造函数
    function Food(width,height,color) {
      this.width=width||20;//默认的小方块的宽
      this.height=height||20;//默认的小方块的高
      //横坐标,纵坐标
      this.x=0;//横坐标随机产生的
      this.y=0;//纵坐标随机产生的
      this.color=color;//小方块的背景颜色
      this.element=document.createElement("div");//小方块的元素
    }
    //初始化小方块的显示的效果及位置---显示地图上
    Food.prototype.init=function (map) {
      //设置小方块的样式
      var div=this.element;
      div.style.position="absolute";//脱离文档流
      div.style.width=this.width+"px";
      div.style.height=this.height+"px";
      div.style.backgroundColor=this.color;
      //把小方块加到map地图中
      map.appendChild(div);
      this.render(map);
    };
    //产生随机位置
    Food.prototype.render=function (map) {
      //随机产生横纵坐标
      var x=Random.getRandom(0,map.offsetWidth/this.width)*this.width;
      var y=Random.getRandom(0,map.offsetHeight/this.height)*this.height;
      this.x=x;
      this.y=y;
      var div=this.element;
      div.style.left=this.x+"px";
      div.style.top=this.y+"px";
    };
    //实例化对象
    var fd=new Food(20,20,"green");
    fd.init(map);
    console.log(fd.x+"===="+fd.y);
  })(window);
  // function refresh(){
  //   window.location.reload();
  // }
  // setTimeout(refresh(), 1000);
</script>
</body>
</html>
相关文章
|
10月前
|
JavaScript 前端开发
【JS 经典面试题】全局变量和局部变量
【JS 经典面试题】全局变量和局部变量
76 1
|
JavaScript 前端开发 Go
JavaScript 局部变量和外部变量(ES6以前)
函数的作用域表示在函数内部定义的变量,只有在函数内部可以被访问到;
109 0
JavaScript 局部变量和外部变量(ES6以前)
|
JavaScript 前端开发
JavaScript之局部变量
引入 在笔者讲解JavaScript变量的时候就曾提到,最好每个变量都用var进行声明,再对其赋值或进行其他运算操作,否则JS会有容错机制,将其自动声明成全局变量。这样可能带来变量冲突。那时我们还引入了一个strict模式来强制每个变量都经过var声明 那么这个“全局变量”到底意味着什么呢?与之相对的“局部变量”又该如何理解呢?本期就将进行函数体内“局部变量”的讲解,争取理解变量作用域并避免变量冲突。
|
存储 JavaScript 前端开发
web前端学习(三十四)——JavaScript对象、函数及作用域(全局变量、局部变量)的相关设置
web前端学习(三十四)——JavaScript对象、函数及作用域(全局变量、局部变量)的相关设置
web前端学习(三十四)——JavaScript对象、函数及作用域(全局变量、局部变量)的相关设置
|
JavaScript 前端开发 测试技术
JS的局部变量和全局变量
两段JS代码的区别:    var a = "Hello";   function test(){        var a;        alert(a);        a = "World";        alert(a);   }         var a = "Hello";   f...
878 0
|
JavaScript
js如何获得局部变量的值
方法一: var a; //全局变量 function test(){ var b=20; //局部变量   return b; //返回局部变量的值 }; a=test(); //将函数返回值赋给全局变量a alert("全局变量a的值是: "+a); 方法二: var a=0;//全局变量...
885 0
|
JavaScript 前端开发 测试技术
Javascript:谈谈JS的全局变量跟局部变量
[javascript] view plain copy &lt;script type="text/javascript"&gt;    var a = "Hello";    function test(){         var a;         alert(a);         a = "Wor
1360 0
|
JavaScript 前端开发
javascript 全局变量 局部变量 var 与不加var的区别
一、外部的为全局,内部的为局部变量。   二、加var为局部变量(在方法内),不加var为全局变量(当方法内有一次使用后) var golbe="global"; test(); function test(){ var local="local"; document.
819 0