在div中不使用js怎么直接调用函数?

JavaScript019

在div中不使用js怎么直接调用函数?,第1张

要想函数自执行,你可以使用一个自执行函数来封装01.js中的内容

(() =>{

var time = new Date()

var y = time.getFullYear()

var m = time.getMonth() + 1

var d = time.getDate()

document.getElementById("b1").innerText =y +"年" + m +"月" + d +"日"

})()

同时由于代码读取都在从上往下的,这时候获取id为b1的这个方法无法获取到,这时候把引入放在dom结构后面就好 如下

<html>

<hear>

<meta charset="UTF-8">

<title>练习</title>

</hear>

<body>

<div>

<b id="b1">

</b>

</div>

<script src="01.js"></script>

</body>

</html>

闭包是指有权访问另外一个函数作用域中的变量的函数。

闭包就是函数的局部变量集合,只是这些局部变量在函数返回后会继续存在。闭包就是就是函数的“堆栈”在函数返回后并不释放,我们也可以理解为这些函数堆栈并不在栈上分配而是在堆上分配。当在一个函数内定义另外一个函数就会产生闭包。

作用是:匿名自执行函数:我们知道所有的变量,如果不加上var关键字,则默认的会添加到全局对象的属性上去,这样的临时变量加入全局对象有很多坏处,比如:别的函数可能误用这些变量;造成全局对象过于庞大,影响访问速度(因为变量的取值是需要从原型链上遍历的)。除了每次使用变量都是用var关键字外,我们在实际情况下经常遇到这样一种情况,即有的函数只需要执行一次,其内部变量无需维护,可以用闭包。

结果缓存:我们开发中会碰到很多情况,设想我们有一个处理过程很耗时的函数对象,每次调用都会花费很长时间,那么我们就需要将计算出来的值存储起来,当调用这个函数的时候,首先在缓存中查找,如果找不到,则进行计算,然后更新缓存并返回值,如果找到了,直接返回查找到的值即可。闭包正是可以做到这一点,因为它不会释放外部的引用,从而函数内部的值可以得以保留。