JS-高程3(更新中...)
附录A
名词解析:
const:声明常量,常量的值不能通过重新赋值来改变,并且在初始赋值后,不能重新声明、重新赋值了。 即:同一作用域中,常量名不能与其他变量或函数名重名。值也不能修改了。
“常量是块级作用域,很像使用let语句定义的变量。”
- 只读的常量,就是只能读一读,不可以通过赋值改变其值,也不可以在脚本运行时重新声明,他必须被初始化某个值。
- 作用域规则和let块级作用域变量相同,若省略const,则被视为变量。
- 在同一作用域中,不能使用与变量名或者函数名相同的名字来命名常量:很好理解,常量设定后就不能变了,你若与变量名字相同,常量和变量功能不同,你让人家js把你设定的常量当常量还是变量?变量是可以改变的,你名字相同相当于改了第一个设了此名字的变量,但是常量不能改,所以就不能和别人一样。
- 如果常量是对象,那么对象的属性是不被保护的,就像变量对象一样,其属性是可以通过再次赋值进而被修改的。
let: 语句声明一个块级作用域的本地变量。
let和var 的区别:
var的变量只有函数作用域,let的变量还有语句块作用域的作用。
看师傅的图,一目了然:
1、块级作用域:任何一对花括号{}中的语句集属于一个块,在这之中定义的所有变量在代码块外都是不可见的。
(原理上是这样的,但是js不支持块级作用域,也就是在for循环中定义的i也能在函数调用的时候取到的一个现象解释、而且在一个函数中的任何位置定义的变量在该函数中的任何地方都是可见的。)
2、函数作用域:定义在函数中的参数和变量在函数外部是不可见的、js拥有函数作用域,所以在一个函数中定义的变量,当这个函数调用完后,变量会被立即销毁。
3、语句块:if、for等语句
4、包含函数:就是包含这个变量或者语句的函数
5、剩余参数:[rest arguments]语法形式是三个点后边跟一个标识符“...nums”,是一个数组,可以用数组的方法来操作。
剩余函数与arguments的区别:
arguments:是一个参数的集合,即使没有参数他也是一个集合,他只有length属性和索引值的方法,不能使用数组的方法
rest arguments:(剩余参数)是一个数组,不管有几个参数。他除了length和索引的属性外,还能用数组的方法操作参数
6、分布参数:[spread arguments] 语法形式是在值得前面加三个点,在调用的时候使用:sum(...[1,2,3])-将数组作为分布参数传给了sum()函数。
剩余参数与分布参数的区别:
剩余参数在定义函数的时候使用,分布参数在调用函数的时候使用。
7、数组领悟:用一组符合某个条件的值来初始化数组;语法形式:array = [ value for each ( variable in values ) condition ];
参数说明:
value: 实际原来数组values中的值;
for each:结构会循环values中的每一个值;
variable:循环出来的每一个值将放在variable中;
condition:可选条件,如果循环出来的值(放在variable中的)符合这个条件,就会被放在最终的数组array中。
这种写法就好像把if判断语句写成了三元表达式一样。同for循环的功能没有区别,但是写法上更加简洁。
//原始数组 var numbers = [0,1,2,3,4,5,6,7,8,9,10]; //把所有元素复制到新数组 var duplicate = [i for each (i in numbers)]; //只把偶数复制到新数组 var evens = [i for each (i in numbers) if (i % 2 == 0)]; //把每个数乘以2 后的结果放到新数组中 var doubled = [i*2 for each (i in numbers)]; //把每个奇数乘以3 后的结果放到新数组中 var tripledOdds = [i*3 for each (i in numbers) if (i % 2 > 0)];
数组领悟示例代码
javascript高级程序设计第三版
JS-高程3(更新中...)的更多相关文章
- 【前端】Util.js-ES6实现的常用100多个javaScript简短函数封装合集(持续更新中)
Util.js (持续更新中...) 项目地址: https://github.com/dragonir/Util.js 项目描述 Util.js 是对常用函数的封装,方便在实际项目中使用,主要内容包 ...
- js坑爹笔试题目汇总(持续更新中)
把你的面试官问倒,你就是一个合格的面试者了,以下总结一些易错的js笔试题目,会持续更新中.欢迎关注 1,考察this var length = 10 function fn(){ alert(this ...
- 前端深入之js篇丨Array数组操作从入门到成神Up Up Up,持续更新中
写在前面 随着前端深入的不断学习,发现数组这个数据结构在前端中有着相当大的存在感,由于我初学前端的时候并没有系统性的学习数组,所以我将通过这篇文章同你一起学习数组,希望我们能一起进步,学会熟练操作数组 ...
- js常见错误类型及chrome常见报错(更新中)
ECMA-262 定义了下列 7 种错误类型: 1.Error 错误 2.EvalError 全局错误 eval函数没有正确执行 3.RangeError 范围错误 4.ReferenceError ...
- 吃透Javascript数组操作的正确姿势—再读《Js高程》
Javascript中关于数组对象的操作方法比较多也比较杂,正好再次捡起<Javascript高级程序设计>来读,把它们一一总结梳理了一下: 方法类别 方法名称 方法描述 参数 返回值 备 ...
- 《JS高程》创建对象的7种方式(完整版)
一.理解对象 ECMA-262定义对象:无序属性的集合,其属性可以包含基本值.对象或者属性. 我们可以把 ECMAScript 的对象想象成 散列表:无非就是一组 名值对,其中值可以是数据或函数. 创 ...
- 《JS高程》事件学习笔记
事件:文档或浏览器窗口中发生的一些特定的交互瞬间,也即用户或浏览器自身执行的某种动作. -------------------------------------------------------- ...
- 《JS高程》JS-Object对象整理
继上篇<JS高程>对象&原型笔记,对JavaScript中的Object对象进行了整理,梳理一遍~ 参考文章:详解Javascript中的Object对象 ------------ ...
- 【翻译】Ext JS 5.0.1 中的新功能
原文:What's New in Ext JS 5.0.1 今天,我们很高兴的宣布Ext JS 5.0.1发布了!此维护版本基于Sencha社区的反馈做了一些改进.下面让我们来了解一下这些改变. 可访 ...
- AngularJS进阶(十二)AngularJS常用知识汇总(不断更新中....)
AngularJS常用知识汇总(不断更新中....) 注:请点击此处进行充电! app.controller('editCtrl',['$http','$location','$rootScope', ...
随机推荐
- C#中对 XML节点进行添加,删除,查找和删除操作
从网上整理所得 XMLDocument来操作XML比较简单,虽然有时效率不是很高.代码如下 已知有一个XML文件(bookstore.xml)如下: <?xml version="1. ...
- 04 memory structure
本章提要--------------------------------------------------SGA: System Global Area ( 包括background process ...
- 03 Files
本章提要-----------------------------------------------组成 oracle 的 8 种主要文件(包括 instance 和 database)instan ...
- 【转】ImageView的Scaletype参数设置
ImageView的Scaletype决定了图片在View上显示时的样子,如进行何种比例的缩放,及显示图片的整体还是部分,等等. 设置的方式包括: 1. 在layout xml中定义Android:s ...
- DTD -- XML验证
DTD(文档类型定义)的作用是定义 XML 文档的合法构建模块. DTD 可被成行地声明于 XML 文档中,也可作为一个外部引用. DTD简介 内部的 DOCTYPE 声明 假如 DTD 被包含在您的 ...
- 文本处理三剑客之AWK的用法
1.awk命令简介: awk是一种可以处理数据.产生格式化报表的语言,功能十分强大. awk的工作方式是读取数据,将每一行数据视为一条记录(record)每笔记录以字段分隔符分成若干字段,然后输出各个 ...
- HDF5 文件格式简介
三代测序下机的原始数据不再是fastq格式了,而是换成了hdf5 格式,在做三代数据的分析之前,有必要先搞清楚hdf5 这种文件格式; 官网的链接如下:https://support.hdfgroup ...
- 刚刚完成了在vs2013中通过 ef连接mysql数据库的工作。感觉没有想象中的简单。试了n次终于成功。故记录成功的方法,希望可以帮到大家
分两种情况,如果你是用entity framework 5.0的时候 mysql-connector-net的版本不是很重要. MySQL For VisualStudio的版本也不重要 (这个不装就 ...
- Tomcat 配置 项目 到tomcat目录外面 和 域名绑定访问(api接口、前端网站、后台管理网站)
先停止tomcat服务 1.进入apache-tomcat-7.0.68/conf/Catalina/localhost(如果之前还都没有启动过tomcat,是不会有此目录的,先启动一次再关闭,会自动 ...
- angular ajax的使用及controller与service分层
一个简单的例子,控制层:.controller('publishController',['$scope','publishService', function($scope,publishServi ...