当前位置: 首页 > news >正文

【JavaScript】14_window对象与JS提升

12、window对象

Window对象

  • 在浏览器中,浏览器为我们提供了一个window对象,可以直接访问
  • window对象代表的是浏览器窗口,通过该对象可以对浏览器窗口进行各种操作
    除此之外window对象还负责存储JS中的内置对象和浏览器的宿主对象
  • window对象的属性可以通过window对象访问,也可以直接访问
  • 函数就可以认为是window对象的方法

向window对象中添加的属性会自动成为全局变量

var 用来声明变量,作用和let相同,但是var不具有块作用域

  • 在全局中使用var声明的变量,都会作为window对象的属性保存
  • 使用function声明的函数,都会作为window的方法保存
  • 使用let声明的变量不会存储在window对象中,而存在一个秘密的小地方(无法访问)
  • var虽然没有块作用域,但有函数作用域
<script>
    // alert(window)
    // window.alert(123)
    // window.console.log("哈哈")

    window.a = 10 // 向window对象中添加的属性会自动成为全局变量
    // console.log(a)

    var b = 20 // window.b = 20
    function fn(){
        alert('我是fn')
    }

    // console.log(window.b)
    // window.fn()

    // let c = 33
    window.c = 44
    // console.log(c)

    function fn2(){
        // var d = 10 // var虽然没有块作用域,但有函数作用域
        d = 10 // 在局部作用域中,如果没有使用var或let声明变量,则变量会自动成为window对象的属性 也就是全局变量
    }
    fn2()
    console.log(d)
</script>

13、提升

变量var的提升

​ - 使用var声明的变量,它会在所有代码执行前被声明

​ 所以我们可以在变量声明前就访问变量(不推荐,不好维护)

函数的提升

​ - 使用函数声明创建的函数,会在其他代码执行前被创建

​ 所以我们可以在函数声明前调用函数

let的提升不显示

let声明的变量实际也会提升,但是在赋值之前解释器禁止对该变量的访问

        <script>
            console.log(b)

            let b = 10

            // fn()

            function fn(){
                alert("我是fn函数~")
            }

            // fn2()
            // var fn2 = function(){

            // }
            // console.log(a)

            var a = 10
            // a = 10 // window.a = 10
        </script>

练习

        <script>
            /* var a = 1
        function fn(){
            a = 2
            console.log(a) // 2
        }
        fn()
        console.log(a) // 2 */

            // 变量和函数的提升同样适用于函数作用域

            /*  var a = 1
        function fn(){
            console.log(a) //undefined
            var a = 2
            console.log(a) // 2
        }
        fn()
        console.log(a) // 1 */

            // 定义形参就相当于在函数中声明了对应的变量,但是没有赋值
            /* var a = 1
        function fn(a){
            console.log(a) //undefined
            a = 2
            console.log(a) // 2
        }
        fn()
        console.log(a) // 1 */

            /* var a = 1
        function fn(a){
            console.log(a) //10
            a = 2
            console.log(a) // 2
        }
        fn(10)
        console.log(a) // 1
 */

            /* var a = 1
        function fn(a){
            console.log(a) //1
            a = 2
            console.log(a) // 2
        }
        fn(a)
        console.log(a) // 1 */

            console.log(a)  // 2

            var a = 1

            console.log(a) // 1

            function a() {
                alert(2)
            }

            console.log(a) // 1

            var a = 3

            console.log(a) // 3

            var a = function () {
                alert(4)
            }

            console.log(a) // 4

            var a

            console.log(a) // 4
        </script>

相关文章:

  • 山东网站制作推荐/职业培训机构哪家最好
  • 河北建设厅网站查询/站长工具seo综合查询广告
  • 绍兴市建设银行网站/综合查询
  • 做网站设计所遇到的问题/it行业培训机构哪个好
  • 模板网站建设公司/百度一下就知道首页
  • 自适应网站制作费用/谷歌官网下载app
  • 8Manage:提高项目执行力的策略有哪些?
  • 【用户交互】
  • 【MATLAB教程案例67】基于Actor-Critic结构强化学习的车杆平衡控制系统matlab仿真
  • 预约挂号系统技术点详解(二)
  • 谈谈vue的路由守卫和keep-alive后生命周期
  • 过半985、单岗位2K+简历!速腾聚创如何开展校园招聘?
  • SpringBoot封装响应处理
  • 基于注解方式Spring Security忽略拦截
  • docker rootless安装
  • redis 大key 防坑指南
  • 智能指针shared_ptr之引用计数
  • RocketMQ-双主双从集群+DashBorad搭建(云服务器)