书名

"学徒"=>"忍者"

性能分析

console.time('sss')
console.timeEnd('sss')

函数

函数是第一类对象

通过字面量创建
function minjaFunction(){} 在变量或数组或者对象中的函数 let obj = {
name: 'zhangsan',
age() {
return 1
}
};
let arr = [1, 2, 3, 4, () => {
return 1;
}];
let nums=()=>{} 作用函数的参数来传递(高阶函数) add=(x,y,f)=>{
return f(x)+f(y)
};
add(1,3,x=>x); 作用函数的返回值(闭包) add=()=>{
let a=1;
return ()=>{
console.log(a)
}
} 具有动态创建和分配的属性(回调函数) var add=function(){
console.log(add.age);
};
add.age='zhangsan';
add(); 回调函数
函数作用另一个函数的参数,随后通过参数来调用该函数
function useless(nin){
return nin();
}

函数和对象的唯一区别

函数是可调用的,函数会被调用执行某项动作或者功能

纯函数缓存??

定义函数的方式

函数声明
function myFunction(){} 箭头函数(lambda函数)
item=>item*2 函数构造函数
let add=new Function('a','b','return a+b')
console.log(add(1, 3)); 生成器构造函数 function* myGen(){
yield 1;
} let a = myGen();
console.log(a.next()); 函数表达式
let a=()=>{} 立即执行函数
()()
+function(){}();
-function(){}();
!function(){}();
~function(){}();

函数的实参+形参

形参是定义的时候传递的变量
实参是调用的时候传递的变量 剩余参数
...
默认参数
a=(a,b=0)=>{}

函数调用

this: 调用函数的上下文对象

arguments 参数表示函数调用过程中传递的所有参数
... 代替了arguments要做的事
let a=(...b)=>{console.log(b)} //箭头函数没有arguments function a(){
console.log(Array.from(arguments));
}
> argumeng.length
> arguments是个伪数组 function fun(a = 3) {
arguments[0]=133;
console.log(a);
}
fun(10);//10
arguments只看调用的参数 调用函数的四种方式
* 作用函数
> func() 直接调用
> 作用函数被调用 this->window
* 作为方法
> a.func() 关联在一个对象上,实现面向对象编程
> 作用方法被调用,this-> 这个对象
* 构造函数
> new func() 实例化一个新的对象
> new 调用函数会触发
> 创建一个新的空对象
> 该对象作用this参数传递给构造函数
> 新构造的对象作为new运算符的返回值 * 通过函数的apply和call
> func.apply(null,[a,b])
> func.call(null,a,b)
* 通过bind() 改变this的指向 需要在后面加上() 让他执行

..........................................................................................................................................................

javascript 忍者秘籍读书笔记的更多相关文章

  1. javascript 忍者秘籍读书笔记(二)

    闭包的私有变量 function Ninja() { let feints = 0; this.getFeints = function () { return feints }; this.fein ...

  2. 《javascript权威指南》读书笔记——第二篇

    <javascript权威指南>读书笔记——第二篇 金刚 javascript js javascript权威指南 今天是今年的196天,分享今天的读书笔记. 第2章 词法结构 2.1 字 ...

  3. 《javascript权威指南》读书笔记——第一篇

    <javascript权威指南>读书笔记——第一篇 金刚 javascript js javascript权威指南 由于最近想系统学习下javascript,所以开始在kindle上看这本 ...

  4. 《JavaScript高级程序设计》读书笔记--前言

    起因 web编程过程使用javascript时感觉很吃力,效率很低.根本原因在于对javascript整个知识体系不熟,看来需要找些书脑补一下,同时欢迎众网友监督. 大神推荐书籍 看了博客大神们推荐的 ...

  5. 《Javascript高级程序设计》读书笔记之对象创建

    <javascript高级程序设计>读过有两遍了,有些重要内容总是会忘记,写一下读书笔记备忘 创建对象 工厂模式 工厂模式优点:有了封装的概念,解决了创建多个相似对象的问题 缺点:没有解决 ...

  6. 《javascript权威指南》读书笔记(连载)

    这是一篇很长的博客 终于把权威指南给买回来了,之前一直犹豫,第一:书太厚,怕买了不能坚持看完.第二:觉得太贵,最少100¥.现在实习也能发点工资了,给自己定了一个志愿:把一个月的工资用于买书.这么一想 ...

  7. 《JavaScript权威指南》读书笔记(一)

    日期 2015-11-28 把之前的读书笔记在我弄丢它之前搬过来~~ 时间过去好久,回头一看理解都不一样了. 重点浏览了一下和Java的不同之处: js是一种宽松类型语言:js不区别整形数值与浮点型数 ...

  8. 你不知道的Javascript(上卷)读书笔记之一 ---- 作用域

    你不知道的Javascript(上卷)这本书在我看来是一本还不错的书籍,这本书用比较简洁的语言来描述Js的那些"坑",在这里写一些博客记录一下笔记以便消化吸收. 1 编译原理 在此 ...

  9. JavaScript忍者秘籍——函数(下)

    概要:本篇博客主要介绍函数的一些类型以及常见示例 1.匿名函数 使用匿名函数的常见示例: window.onload = function(){ assert(true,'power!'); }; / ...

随机推荐

  1. Python检测URL状态

    需求:Python检测URL状态,并追加保存200的URL 代码一: #! /usr/bin/env python #coding=utf-8 import sys import requests d ...

  2. Java 之 枚举(Enum)

    一.枚举 1.概述 枚举:JDK1.5引入的,类似于穷举,一一罗列出来 Java 枚举:把某个类型的对象,全部列出来 2.应用 什么情况下会用到枚举类型? 当某个类型的对象是固定的,有限的几个,那么就 ...

  3. sqli-libs笔记Page-1(Basic Challenges)

    0X00:前言 sqli-libs是一个学习SQL注入的开源平台,共有75中不同类型的注入.源码可到github上搜索sqli-libs找到 0X01:Page-1基础挑战 0X02:每一关的payl ...

  4. 易语言 MD5生成

    下载MD5脚本 https://download.csdn.net/download/zhangxuechao_/10573121 添加脚本组件 定义常量 生成MD5

  5. React Navigation 导航栏样式调整+底部角标消息提示

    五一佳节匆匆而过,有人选择在外面看人山人海,有人选择宅在家中度过五一,也有人依然坚守在第一线,致敬! 这是坚持学习react-native的第二篇文章,可能会迟到,但是绝不会缺席,这篇要涉及到的是re ...

  6. Global variable in ABAP function group

    Function group is loaded into runtime memory by the FIRST call of a function module inside this func ...

  7. elasticsearch安装中文分词器插件smartcn

    原文:http://blog.java1234.com/blog/articles/373.html elasticsearch安装中文分词器插件smartcn elasticsearch默认分词器比 ...

  8. eclipse IDE 32位汉化方法及常用软件汉化包寻找办法

    今天听说小组开发人员遇到安装eclipse不能汉化问题.了解到其他同事用的都是64位操作系统,这个同事用的32位系统.通常情况下常用软件都有各路大神发的成熟汉化包,不会出现无法安装汉化包的情况. 先找 ...

  9. Kubernetes基础服务架构图

    最近看了一些kubernetes的相关资料, 简单的画了一个原理图 欢迎大家批阅

  10. VUE简单的语法

    这篇主要记录了在使用过程的当中,对于vue的一些方法的理解 1.Vue生命周期中mounted和created的区别 created:在模板渲染成html前调用,即通常初始化某些属性值,然后再渲染成视 ...