javaScript 基础知识汇总(九)
1、Rest 参数 与 Spread 操作符
当我们在代码中遇到“..."时,它不是Rest参数就是Spread操作符
区分方法:
若...出现在函数的参数列表,那它表示的就是Rest参数,它会把函数多余的实参收集到一个数组中。
1 function sumAll(...args) { // 数组变量名为 args
2 let sum = 0;
3
4 for (let arg of args) sum += arg;
5
6 return sum;
7 }
8
9 alert( sumAll(1) ); // 1
10 alert( sumAll(1, 2) ); // 3
11 alert( sumAll(1, 2, 3) ); // 6
若... 出现在函数调用或类似的表达式中,那么它就是Spread操作符,它会把一个数组展开为逗号分隔的元素列表。
1 let arr = [3, 5, 1];
2
3 alert( Math.max(...arr) ); // 5(Spread 操作符把数组转为参数列表)
1 let str = "Hello";
2
3 alert( [...str] ); // H,e,l,l,o
2、旧时的“var”
“var”没有块级作用域
function sayHi() {
if (true) {
var phrase = "Hello";
let test = "aa"
}
alert(phrase); // works
alert(test);//报错 test is not defined
}
sayHi();
alert(phrase); // 报错:phrase is not defined
“var” 在函数开头被处理
function sayHi() {
phrase = "Hello";
alert(phrase);
var phrase;
}
和下面等同
function sayHi() {
var phrase;
phrase = "Hello";
alert(phrase);
}
或者代码块被忽略
function sayHi() {
phrase = "Hello"; // (*)
if (false) {
var phrase;
}
alert(phrase);
}
此时的变量仍可以被访问
3、全局对象
概念:全局对象提供在任何地方使用的变量和函数。大多情况下,这些局部变量内置与语言或主机环境中。浏览器中它被命名为window。
window 对象
1)作为全局对象外,还有浏览器窗口功能,
alert(window.innerHeight);//显示浏览器窗口高度
window.open('http://www.baidu.com')//打开一个新窗口
2)顶级var 变量和函数声明后自动成为window属性
var x = 5;
alert(window.x)//5 这样可以访问x
但是 let/const 声明不会发生这种情况,因为这两个的声明不会给window 创建属性
3) 正常情况下,所有脚本代码共享相同的全局作用域
<script>
var a = ;
let b = ;
</script> <script>
alert(a); //
alert(b); //
</script>
4)全局范围内 this 的值为 window
alert(this);//window
这样会可能导致命名冲突
所以现在有了一个解决办法就是给 type设置 “module” 属性
//在一个模块中, var x 不会成为window属性
<script type="module">
var x = ; alert(window.x); // undefined
</script> //两个模块的变量彼此不可见
<script type="module">
let x = ;
</script> <script type="module">
alert(window.x); // undefined
alert(x); // 错误:未声明的变量
</script> //在模块中 this 的顶级变量为 undefined
<script type="module">
alert(this); // undefined
</script>
4、函数对象
属性 “name"
function sayHi() {
alert("Hi");
}
alert(sayHi.name); // sayHi
属性 "length"
这个属性是用来返回函数传入参数的个数
function f1(a) {}
function f2(a, b) {}
function many(a, b, ...more) {}
alert(f1.length); //
alert(f2.length); //
alert(many.length); //
但是余参不参与计数
自定义属性
function sayHi() {
alert("Hi");
// 我们记录一下运行次数
sayHi.counter++;
}
sayHi.counter = ; // 初始值
sayHi(); // Hi
sayHi(); // Hi
alert( `调用了 ${sayHi.counter} 次` ); // 调用了 2 次
命名函数表达式
1)这个名字允许在函数内部引用自己
2)在函数外部是不可见的
let sayHi = function func(who) {
if (who) {
alert(`Hello, ${who}`);
} else {
func("Guest"); // 使用 func 再次调用自己
}
};
sayHi(); // Hello, Guest
// 但这个无法生效
func(); // Error, func is not defined(在函数外不可见)
javaScript 基础知识汇总(九)的更多相关文章
- JavaScript基础知识汇总
1. 图片热区: <img src="logo.jpg" usemap="#logo"> <map id="logo" n ...
- javaScript 基础知识汇总(三)
1.循环:while 和 for while 循环 while(condition){ //代码 循环体 } do ... while 循环 let i =0; do { //循环体 }while( ...
- javaScript 基础知识汇总(六)
1.基本类型与对象的区别 基本类型:是原始类型的中的一种值. 在JavaScript中有6中基本类型:string number boolean symbol null undefined 对 ...
- javaScript 基础知识汇总(五)
1.垃圾回收 JavaScript 的内存管理是自动的,不能强制执行或者阻止执行 可达性 JavaScript中主要的内存管理概念是可达性. 什么是可达性? 定义一个对象 let user = { n ...
- javaScript 基础知识汇总(二)
1.运算符 术语或者叫法:一元运算符.二元运算符.运算元(参数) let x=0; x=5+2; //5和2为运算元,“+” 为二元运算符: x=-x; //"-" 为一元运算符 ...
- javascript 基础知识汇总(一)
1.<script> 标签 1) 可以通过<script> 标签将javaScript 代码添加到页面中 (type 和language 属性不是必须的) 2)外部的脚本可以通 ...
- JavaScript 基础知识汇总目录
一.标签.代码结构.现代模式.变量.数据类型.类型转换 GO 二.运算符.值的比较.交互.条件运算符.逻辑运算符 GO 三.循环 while 和 for .switch语句.函数.函数表达式和箭头函数 ...
- javaScript 基础知识汇总 (十三)
1.Class 在JavaScript中 calss即类是一种函数 基本语法 class Myclass{ constructor(){} method1(){} method2(){} method ...
- javaScript 基础知识汇总(七)
1.数组 特点:数组是可以存储有序集合的对象. 声明: let arr = new Array(); let arr=[]; 大多数情况下我们使用第二种. let fruits = [" ...
随机推荐
- WEB前端资源集(二)
在上一篇为大家整理出了一些资源网站,接下来给大家整理了一些开发中常用的工具. 开发工具篇 开发工具集 Sublime Text 3:SublimeText 3是一个代码编辑器,也是HTML和散文先进的 ...
- in与exist , not in与not exist 的区别
in和exists in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询.一直以来认为exists比in效率高的说法是不准确的. ...
- drf三大认证
源码分析 """ 1)APIView的dispath(self, request, *args, **kwargs) 2)dispath方法内 self.initial( ...
- ssm框架下怎么批量删除数据?
ssm框架下批量删除怎么删除? 1.单击删除按钮选中选项后,跳转到js函数,由函数处理 2. 主要就是前端的操作 js 操作(如何全选?如何把选中的数据传到Controller中) 3.fun()函数 ...
- App自动化测试方案
App自动化测试方案 1.1 概述 什么是App自动化?为什么要做App自动化? App自动化是指给 Android或iOS上的软件应用程序做的自动化测试. 手工测试和自动化测试的对比如下: 手工测 ...
- 【bzoj3441】乌鸦喝水
Source bzoj3441 Hint 请先思考后再展开 按被删除的顺序考虑每个点,然后按照题意模拟 Solution 请先思考后再展开 被删除的顺序一定是按照[能被操作的次数]为第一关键字,位置作 ...
- MySQL 的 RowNum 实现(排行榜计算用户排名)
1. 计算用户排名最高效的方法 例如:通过用户分享个数排名,那么自己的排名就是:比自己分享数多的用户个数 + 1 ' and `count` > '自己分享个数' 缺点:当多个用户分享个数相同的 ...
- sycCMS PHP V1.0---呵呵呵呵呵
闲的无聊,随便找了份代码看了看. //search.php 第17行 第49行 ...... $keyword=SafeRequest("keyword","post&q ...
- 有关终端的一些tips
reg.exe是用于操作注册表的命令,可以通过reg /?来查看所有参数,在pentest中有两个很实用的参数 reg query 读取注册表信息, reg add 添加或修改注册表内容. 设想如下场 ...
- 原创:Python爬虫实战之爬取代理ip
编程的快乐只有在运行成功的那一刻才知道QAQ 目标网站:https://www.kuaidaili.com/free/inha/ #若有侵权请联系我 因为上面的代理都是http的所以没写这个判断 代 ...