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 基础知识汇总(九)的更多相关文章

  1. JavaScript基础知识汇总

    1. 图片热区: <img src="logo.jpg" usemap="#logo"> <map id="logo" n ...

  2. javaScript 基础知识汇总(三)

    1.循环:while 和 for while 循环 while(condition){ //代码 循环体 } do ... while  循环 let i =0; do { //循环体 }while( ...

  3. javaScript 基础知识汇总(六)

    1.基本类型与对象的区别 基本类型:是原始类型的中的一种值. 在JavaScript中有6中基本类型:string number  boolean  symbol  null  undefined 对 ...

  4. javaScript 基础知识汇总(五)

    1.垃圾回收 JavaScript 的内存管理是自动的,不能强制执行或者阻止执行 可达性 JavaScript中主要的内存管理概念是可达性. 什么是可达性? 定义一个对象 let user = { n ...

  5. javaScript 基础知识汇总(二)

    1.运算符 术语或者叫法:一元运算符.二元运算符.运算元(参数) let x=0; x=5+2; //5和2为运算元,“+” 为二元运算符: x=-x; //"-" 为一元运算符 ...

  6. javascript 基础知识汇总(一)

    1.<script> 标签 1) 可以通过<script> 标签将javaScript 代码添加到页面中 (type 和language 属性不是必须的) 2)外部的脚本可以通 ...

  7. JavaScript 基础知识汇总目录

    一.标签.代码结构.现代模式.变量.数据类型.类型转换 GO 二.运算符.值的比较.交互.条件运算符.逻辑运算符 GO 三.循环 while 和 for .switch语句.函数.函数表达式和箭头函数 ...

  8. javaScript 基础知识汇总 (十三)

    1.Class 在JavaScript中 calss即类是一种函数 基本语法 class Myclass{ constructor(){} method1(){} method2(){} method ...

  9. javaScript 基础知识汇总(七)

    1.数组 特点:数组是可以存储有序集合的对象. 声明: let arr = new Array();   let arr=[]; 大多数情况下我们使用第二种. let fruits = [" ...

随机推荐

  1. MySQL 之全文索引

    最近在复习数据库索引部分,看到了 fulltext,也即全文索引,虽然全文索引在平时的业务中用到的不多,但是感觉它有点儿意思,所以花了点时间研究一下,特此记录. 引入概念通过数值比较.范围过滤等就可以 ...

  2. Jenkins 2 如何使用 PowerShell 以及自定 build fail (指定 exit code)

    Jenkins 除了用來做為 CI(持續性整合) 工具外,也可以與其他 plugin 配合達成其他目的(e.g.IIS restart.檔案壓縮備份-),今天就來看看可以怎麼與 PowerShell ...

  3. Python 零基础入门

    Python 零基础入门 1.1 Python介绍 Python 是一门优雅且健壮的面向对象解释型计算机程序编程语言,具有面向对象.可升级.可扩展.可移植 语法简洁清晰易学.易读写.易维护.健壮性.通 ...

  4. 通过IE私有滤镜让IE6 7 8支持背景透明,内容不透明效果。

    CSS3已经支持背景rgba的rgba透明度,这一方法可以避免元素内容也随背景一起变透明(详情请阅http://www.cssha.com/css3-new-knowledge-student).但是 ...

  5. Python——1变量和数据类型(内含其他知识点链接)

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...

  6. 国际控制报文协议ICMP

    国际控制报文协议ICMP ICMP简介 ICMP 用于主机或路由器报告差错情况和提供有关异常情况的报告(检测网络错误). ICMP 不是高层协议,而是 IP 层的协议. ICMP 报文的格式 ICMP ...

  7. Docker深入浅出系列 | 单机Nginx+Springboot实战

    目录 Nginx+Springboot实战 前期准备 实战目标 实战步骤 创建Docker网络 搭建Mysql容器 搭建额度服务集群 搭建Nginx服务 验证额度服务 附录 Nginx+Springb ...

  8. Ribbon进行服务调用/负载均衡以及请求重试配置

    Ribbon负载均衡 经过对Eureka的认识,及Eureka集群的搭建,已经基本可以入门Eureka的使用.之前对于服务调用者我们是直接获取注册列表后通过 get(0) 的方式来获取第一个注册信息. ...

  9. 有点长的博客:Redis不是只有get set那么简单

    我以前还没接触Redis的时候,听到大数据组的小伙伴在讨论Redis,觉得这东西好高端,要是哪天我们组也可以使用下Redis就好了,好长一段时间后,我们项目中终于引入了Redis这个技术,我用了几下, ...

  10. kafka知识整理

    title: kafka知识整理 date: 2019-06-18 10:59:46 categories: MQ tags: kafka --- 转载自:https://www.cnblogs.co ...