ECMAScript学习笔记
1. ECMAScript不存在块级作用域,因此在循环内部定义的变量,在循环外也是可以访问的
eg:
var count =10;
fpr(var i=0; i<count; i++){
alert(i);
}
alert(i); //10
2. ECMAScript的函数可以定义任意个参数,传入任意个参数两者可以不对应;
在调用函数时传入的参数会存放在arguments[]中,定义函数时写的参数相当于为arguments[]中对应的参数起别名
arguments[]的长度由调用函数时传入的参数决定
在两者存在对应关系时,修改任意一个的值,另一个也会同时改变
eg:
function showArguments(num1,num2,num3){
num2 = 10;
arguments[2] = 100;
console.log(num1+' '+num2+' '+num3+': '+arguments[0]+' '+arguments[1]+' '+arguments[2]);
}
showArguments(); //"undefined 10 undefined: undefined undefined 100"
showArguments(1); //"1 10 undefined: 1 undefined 100"
showArguments(1,1); //"1 10 undefined: 1 10 100"
showArguments(1,1,1); //"1 10 100: 1 10 100"
showArguments(1,1,1,1); //"1 10 100: 1 10 100"
3. ECMAScript的所有函数的参数都是按值传递的,会把调用时参数的值付给函数内部的参数,
(ps:当参数是基本数据类型时,不关函数如何操作都不会改变外部参数的值;
但是当参数是引用数据类型时,因为外部参数和内部参数指向同一内存区域,
在函数内改变对象属后,在其他地方访问该对象的也是改变后的,
不过同样的在函数内改变参数的值指向其他地址,依然不会影响外部参数的值)
eg:
var obj = new Object();
function setName(obj){
obj.name = "Regis";
}
function setTitle(obj){
obj.title = "king of lucis";
obj = new Object();
obj.title = "nilheim";
}
setName(obj);
setTitle(obj);
console.log(obj.name); //"Regis"
console.log(obj.title) //"king of lucis"
4.ECMAScript中Array类型的迭代方法
a.every(function(item,index,array){}):对数组中的每一项运行给定函数,如果函数对每一项都返回true,则返回true。
b.some(function(item,index,array){}):对数组中的每一项运行给定函数,如果该函数对任一项返回true,则返回true.
c.filter(function(item,index,array){}):对数组中的每一项运行给定函数,返回该函数返回true的项组成的数组.
d.forEach(function(item,index,array){}):对数组中的每一项运行给定的函数。该方法没有返回值
e.map(function(item,index,array){}):对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组.
ECMAScript学习笔记的更多相关文章
- JavaScript中的EcMAScript学习笔记
一.Javascript概述(知道) a.一种基于对象和事件驱动的脚本语言 b.作用: 给页面添加动态效果 c.历史: 原名叫做livescript.W3c组织开发的标准叫ECMAs ...
- ECMAScript —— 学习笔记(思维导图版)
导图
- 【前端】Web前端学习笔记【1】
... [2015.12.02-2016.02.22]期间的学习笔记. 相关博客: Web前端学习笔记[2] 1. JS中的: (1)continue 语句 (带有或不带标签引用)只能用在循环中. ( ...
- ASP.NET MVC Web API 学习笔记---第一个Web API程序
http://www.cnblogs.com/qingyuan/archive/2012/10/12/2720824.html GetListAll /api/Contact GetListBySex ...
- JS 学习笔记--9---变量-作用域-内存相关
JS 中变量和其它语言中变量最大的区别就是,JS 是松散型语言,决定了它只是在某一个特定时间保存某一特定的值的一个名字而已.由于在定义变量的时候不需要显示规定必须保存某种类型的值,故变量的值以及保存的 ...
- Java程序猿JavaScript学习笔记(4——关闭/getter/setter)
计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...
- JavaScript学习笔记(十五)——对象之Date,RegExp
在学习廖雪峰前辈的JavaScript教程中,遇到了一些需要注意的点,因此作为学习笔记列出来,提醒自己注意! 如果大家有需要,欢迎访问前辈的博客https://www.liaoxuefeng.com/ ...
- ArcGIS API for JavaScript 4.2学习笔记[0] AJS4.2概述、新特性、未来产品线计划与AJS笔记目录
放着好好的成熟的AJS 3.19不学,为什么要去碰乳臭未干的AJS 4.2? 4.2全线基础学习请点击[直达] 4.3及更高版本的补充学习请关注我的博客. ArcGIS API for JavaScr ...
- Underscore.js 源码学习笔记(下)
上接 Underscore.js 源码学习笔记(上) === 756 行开始 函数部分. var executeBound = function(sourceFunc, boundFunc, cont ...
随机推荐
- Nginx+Php中限制站点目录防止跨站的配置方案记录
Nginx+Php中限制站点目录防止跨站的配置方案记录(使用open_basedir)-------------------方法1)在Nginx配置文件中加入: 1 fastcgi_param PH ...
- 如果您无法使用Docker的存储库来安装Docker CE
如果您无法使用Docker的存储库来安装Docker CE,则可以下载.deb适用于您的发行版的 文件并手动安装.每次要升级Docker CE时都需要下载新文件. 转到https://download ...
- [BZOJ1575] [Usaco2009 Jan]气象牛Baric(DP)
传送门 DP f[i][j]表示前i个中选j个的最优解 预处理g[i][j]表示选i~j对答案的贡献 那么就可以n^3乱搞了! 注意边界 #include <cstdio> #includ ...
- 【DFS序+单点修改区间求和】POJ 3321 Apple Tree
poj.org/problem?id=3321 [题意] 给一棵n个节点的树,每个节点开始有一个苹果,m次操作 1.将某个结点的苹果数异或 1 2.查询一棵子树内的苹果数 #include<io ...
- 文艺平衡树(bzoj 3223)
Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 ...
- 还是Tomcat,关于类加载器的趣味实验
一.前言 类加载器,其实是很复杂一个东西,想等到我完全什么都弄明白了再写出来,估计不太现实...现在只能是知道多少写多少吧. 首先,我提一个问题:在我们自己的servlet中(比如ssm中,contr ...
- 「CodePlus 2018 3 月赛」白金元首与莫斯科
$n \leq 17,m \leq 17$,$n*m$的01矩形,对每一个0问:当他单独变成1之后,在其他0处放多米诺牌(不一定放满,可以不放)的方案数.膜$1e9+7$. 直接$dp$是$n^42^ ...
- (5)Swing事件
import javax.swing.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; publi ...
- 快速掌握RabbitMQ(四)——两种消费模式和QOS的C#实现
本篇介绍一下RabbitMQ中的消费模式,在前边的所有栗子中我们采用的消费者都是EventingBasicConsumer,其实RabbitMQ中还有其他两种消费模式:BasicGet和QueueBa ...
- Ubuntu官方Wiki教程资源
前言:通常学习一样新知识时,最快的方式是通过搜索引擎然后以最快的方式拿枪上战场,如果接下来还一直依赖搜索引擎去打,那么你会发现自己永远都在打游击:那么如果要解决这个问题,必须要学会系统的学习,只有连贯 ...