Javascript备忘复习笔记2
一.函数与形参
1.函数
function abs(x) {
if (x >= 0) {
return x;
} else {
return -x;
}
}
alert(abs(-10));
2.匿名函数
var abs = function (x) {
if (x >= 0) {
return x;
} else {
return -x;
}
}
alert(abs(-10));
3.argument传入参数
- 普通函数写法
function abs() {
if (arguments.length === 0) {
return 0;
}
var x = arguments[0];
return x >= 0 ? x : -x;
}
abs(); //
abs(10); //
abs(-9); //
- 匿名函数写法
var abs = function () {
if (arguments.length === 0) {
return 0;
}
var x = arguments[0];
return x >= 0 ? x : -x;
}
alert(abs(-10)); //
4.任意参数(类似python的def foo(a,*b,**c): pass)
function foo(a, b, ...rest) {
console.log('a = ' + a);
console.log('b = ' + b);
console.log(rest);
}
foo(1, 2, 3, 4, 5);
// 结果:
// a = 1
// b = 2
// Array [ 3, 4, 5 ]
foo(1);
// 结果:
// a = 1
// b = undefined
// Array []
二.变量作用域
1.所有的变量都会绑定到window中;
2.JavaScript的函数会先扫描整个函数体的语句,把所有申明的变量“提升”到函数顶部;
3.let/const可替代var申明一个块级作用域的变量(局部变量)
三.方法
1.在一个方法内部,this是一个特殊变量,它始终指向当前对象(只作用一层,如果函数内部再定义一层函数,那么里面这个函数的this会指向undefined,补救方法就是引入 var that = this;)
function getAge() {
var y = new Date().getFullYear();
return y - this.birth;
}
var xiaoming = {
name: '小明',
birth: 1990,
age: getAge //此处为函数,不为函数的调用
};
xiaoming.age(); // 25, 正常结果
//错误写法
var fn = xiaoming.age; // 反例,先拿到xiaoming的age函数
fn(); // NaN
- 有点疑惑的是:
//正确写法
var xiaoming = {
name: '小明',
birth: 1990,
age: function () {
var that = this;
function getAgeFromBirth() {
var y = new Date().getFullYear();
return y - that.birth;
}
return getAgeFromBirth();
}
}; alert(xiaoming.age()); //错误写法 var that;
function getAgeFromBirth() {
var y = new Date().getFullYear();
return y - that.birth;
} var xiaoming = {
name: '小明',
birth: 1990,
age: function () {
var that = this;
return getAgeFromBirth();
}
}; alert(xiaoming.age());
2.js的闭包跟python的不同,python是返回函数,js是返回函数的调用!
3.一般的语言中,都是对象调用方法,但js有个比较有趣的点就是可以反过来用apply实现方法指定对象的目的(这个特性可以修复1中的this->undefined的缺陷)
function getAge() {
var y = new Date().getFullYear();
return y - this.birth;
}
var xiaoming = {
name: '小明',
birth: 1990,
age: function (){
return getAge();
}
};
alert(getAge.apply(xiaoming,[])); //25,正确
alert(xiaoming.age()); //NaN错误
4.apply实现装饰器
略
5.高阶函数
function abs(z){
if(z<0) return -z;
else return z;
}
function add(x,y,f){
return f(x) + f(y);
}
alert(add(-3,5,abs));
6. Map/reduce/filter
var arr = [1, 3, 5, 7, 9];
var fun = function (x, y) {
return x + y;
}
var filt = function (s){
return s % 3 === 0;
}
alert(arr.reduce(fun)); //reduce 25
alert(arr.map(fun)); //map
alert(arr.filter(filt)); //filter 3,9
7.扩展sort排序(高阶函数)
var arr = [10, 20, 1, 2];
var after_sort = arr.sort(function (x,y){
if (x>y){
return 1;
}
if (x<y){
return -1;
}
return 0;
}) alert(typeof(after_sort)); //object
alert(after_sort); //[1,2,10,20]
8.闭包
略
9.箭头函数
var fn = x => x * x;
等价于
var fn = function (x) {
return x*x;
}
10.迭代器
略
Javascript备忘复习笔记2的更多相关文章
- Javascript备忘复习笔记1
一.字符串操作 1.大小写 var s = "hello"; undefined g = s.toUpperCase(); "HELLO" g; "H ...
- Javascript备忘模式
使用备忘模式,利用了函数的自定义属性,先看一个例子 var test = function (){} test.myAttr = "attr"; 这样,就给test加上了一个自定义 ...
- Javascript备忘
js输出对象类型: Object.prototype.toString.apply(s) 设置单行点击效果: obj.style.background = "#efefef";se ...
- Javascript 备忘
1遍历所有属性 var person={fname:"John",lname:"Doe",age:25}; for (x in person) { txt=tx ...
- javascript 备忘 细节 相关
DOMContentLoaded事件触发时机,即dom tree完成但页面未必渲染完毕. var a = [1,2,3,4]; var length = a.length; alert((leng ...
- JavaScript对象(复习笔记)
js对象 对象构造器 function person(firstname,lastname,age,eyecolor){ this.firstname=firstname; this.lastname ...
- JavaScript基础教程复习笔记
document.write("<h1>这是一个标题</h1>"); 您只能在 HTML 输出中使用 document.write.如果您在文档加载后使用该 ...
- git备忘 & ProGit笔记
git configgit config xxxxx xxxx可以是 --global(使用的是~/.gitconfig) --system(据说在linux下面使用的是/etc/gitcon ...
- [备忘]Asp.net MVC 将服务端Model传递的对象转为客户端javascript对象
<script type="text/javascript"> var jsObject = @Html.Raw(Json.Encode(Model.Objects)) ...
随机推荐
- Jquery全选单选功能
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm6.aspx. ...
- mac os intellij如何快路查看一个java类的所有方法,结构
如果是自己写的java类,点击点击导航的project-setting-show members 如果是系统库的,点击structure 再点一下lib中的类,或者快捷键 command+F12
- 怎么样使用yum来安装、卸载jdk
安装好的CentOS会自带OpenJdk,用命令 java -version ,会有下面的信息: java version "1.6.0"OpenJDK Runtime Envi ...
- MVC数据库数据分页显示
首先从数据库获取数据 using System; using System.Collections.Generic; using System.Linq; using System.Web; usin ...
- mysql 判断表字段或索引是否存在
判断字段是否存在: DROP PROCEDURE IF EXISTS schema_change; DELIMITER // CREATE PROCEDURE schema_change() BEGI ...
- 熟练掌握js中this的用法,解析this在不同应用场景的作用
由于其运行期绑定的特性,JavaScript 中的 this 含义要丰富得多,它可以是全局对象.当前对象或者任意对象,这完全取决于函数的调用方式. JavaScript 中函数的调用有以下几种方式:作 ...
- Github入门(一)
之前早就听说过Git的大名,但由于合作项目时的团体都非常小,所以一直没有开始系统的学习和使用(其实就是懒!),最近终于有动力开始进行入门的学习. 首先介绍一下自学用书:https://git-scm. ...
- android Activity生命周期(设备旋转、数据恢复等)与启动模式
1.Activity生命周期 接下来将介绍 Android Activity(四大组件之一) 的生命周期, 包含运行.暂停和停止三种状态,onCreate.onStart.onResume.o ...
- 解决easy ui 1.4datebox控件不能清空的问题
用easy ui遇到这个问题,在网上找到了解决方案,不过是1.3.6版本的.现提供1.4版本的修改的具体位置和代码. 我们用的是这个 修改位置:12739行,添加代码: , { text: funct ...
- c#-轮询算法
这两天做东西,业务上有个特殊的需求,在用户访问页面的时候,针对某一行代码进行控制,按照概率来进行显示,我做的是针对当前页面的曝光进行处理,曝光代码是第三方的,页面上只要有这段代码就算是执行了这段曝光代 ...