console.log(typeof(n)); // undefined
var n = null;
console.log(typeof(n)); // object
有趣的是JS中的对象类型为null。
在ES6之前,var是声明变量的唯一方法。但是现在我们有更多选择。
有一个术语作为范围。范围是指可以使用这些变量的位置。var声明是全局范围的或函数/局部范围的。
可以挂起Var,我们将在几秒钟后讨论。但是,现在让let对于变量声明更可取。当不需要稍后在代码中更改变量时,可以使用const。为了获得两者之间的区别,您可以阅读下面的文章,我认为它非常有用。
在javascript中,可以在声明变量之前使用变量。物理上移到代码顶部的变量和函数声明的概念称为变量提升。
console.log(num); // Returns undefined, as only declaration was hoisted, no initialization has happened at this stage
var num; // Declaration
num = 6;
那么,let和const变量是否不会被悬挂?答案要复杂得多。所有声明(函数,var,let,const和class)都在JavaScript中吊起,而var声明使用undefined初始化,但是let和const声明保持未初始化。
在javascript中,范围分为两种方式。全局和局部。
在函数中声明的变量称为局部作用域。该变量不能在函数外部访问。相反,在函数外部声明的变量称为全局范围。可以在函数内部访问它。
var genre= “superhero” //global scope
// code here can’t use superhero but genre
function myFunction() {
var superhero = “Batman”; // local scope
// code here CAN use superhero and genre
}
闭包使我们可以从内部函数访问外部函数的范围。可以通过从一个函数返回另一个函数来创建它。它为每个实例创建一个封闭的环境。例如:
function sum(x) {
return function(y) {
return x + y;
};
}
var add5 = sum(5);
var add10 = sum(10);
console.log(add5(6)); // 11
console.log(add10(6)); // 16
这里的add5和add10都是闭包。它们共享相同的定义,但存储不同的环境。
根据MDN,回调函数是一个作为参数传递给另一个函数的函数,然后在外部函数内部调用该回调函数以完成某种例程或操作。例如
function greeting(name) {
console.log('Hello ’ + name);
}
function greetEmployee(name,callback) {
callback(name);
}
greetEmployee(“Dwight”,greeting);
在这里,greeting函数已在greetEmployee函数内部使用。这就是我们所谓的回调函数。
感谢阅读本文。希望这能帮助到你。
💌 欢迎大家在评论区提出意见和建议! (抽两位幸运儿送书,实物图如下)💌
《Vue.js框架与Web前端开发从入门到精通》
【内容简介】
**本书从Vue.js框架技术的基础概念出发,逐步深入Vue.js进阶实战,并在最后配合一个网站项目和一个后台系统开发实战案例,重点介绍了使用Vue.js+axios+ElementUI+wangEditor进行前端开发和使用组件进行Vue单页面网页复用,让读者不但可以系统地学习Vue.js前端开发框架的相关知识,而且还能对业务逻辑的分析思路、实际应用开发有更为深入的理解。
本书语言平实,用词诙谐,案例丰富,实用性强,特别适合刚入社会的职场新人、Vue.js框架的初级读者和进阶读者阅读,也适合希望从后台开发转型做前端的程序员等其他编程爱好者阅读。另外,本书也适合作为相关培训机构的教材使用。**
有不想靠抽,想自己买的同学可以参考下面的链接
最后
推荐一些系统学习的途径和方法。
每个Web开发人员必备,很权威很齐全的Web开发文档。作为学习辞典使用,可以查询到每个概念、方法、属性的详细解释,注意使用英文关键字搜索。里面的一些 HTML,CSS,HTTP 技术教程也相当不错。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
HTML 和 CSS: