教程笔记《JavaScript深入浅出》
一、数据类型
javascript是弱数据类型语言,不需要显式的定义类型,一共有如下六种数据类型
五种基本类型:number,string,boolean,null,undefined
一种复合类型:object 对象:Function,Array,Date,Math,...
类型检测:
typeof ***:基本类型检测
*** instanceof ***:复合类型检测,左操作数对象的原型链上是否有右边构造函数prototype
二、表达式和运算符
表达式是指能计算出值的任何可用程序单元
原始表达式:常量、直接量 3.14,“test”
关键字 null,this
变量 i,k,j
表达式含:原始表达式
初始化表达式
函数表达式
属性访问表达式
调用表达式
对象创建表达式
运算符:一元 +num,i++
二元 a+b
三元 c?a:b
按功能:赋值、比较、算术、位、逻辑、字符串、特殊
三、语句
程序由语句组成,语句遵守特定语法规则
块 block {} 没有块级作用域
声明 var
异常 try catch finally
函数声明 function fd(){} 前后都可以引用
函数表达式 var fe=function(){} 只能在后面引用
遍历 for in
条件判断 switch(val) { care; default }
循环 while{} do{} for(){}
严格模式 'use strict'
不允许用with,不允许未声明变量赋值,delete参数和函数报错, 不允许重复属性
四、对象
对象的结构:包含一系列无序的属性,每个属性都有字符串key和对应的值
创建对象:对象字面量、new/原型链、Object.create
对象的属性操作:读写 obj.x 或 obj['x']
异常 不存在等
删除 delete obj.x 或 delete obj['x'],重复删除为true,原型链上的属性不能删除
检测 'x' in obj包括属性在对象或对象 原型链上均为true
枚举
对象的get/set:不一样的属性读写,get默认设置函数,set赋值函数
属性标签:设置obj.defineProperty(obj,'x',{configurable:false,writable:false,enumerable:true,value:'123'})
对象的序列化: JSON.stringify(obj)
对象方法: toString valueOf等
五、数组
数组:值的有序集合
创建数组:字面量,构造器new array()
数组的读写:push() 尾部加入新元素
unshift() 头部加入新元素
pop() 尾部减去元素
shift() 头部减去元素
splice() 中间添加或删除元素
数组的方法:Array.prototype上的方法
arr.join() 数组转字符串
arr.reverse() 数组逆序
arr.sort() 数组排序(默认按字符串)
arr.concat() 数组合并 不操作数组
arr.slice() 返回部分数组 不操作数组
arr.splice() 数组拼接(可对数组中间部分进行添加或删除元素,拼接为新数组) 操作数组
arr.forEach() 数组遍历,对每个数组对象执行指定函数
arr.map() 数组映射,不修改原数组
arr.filter() 数组过滤
arr.every()和arr.some() 数组遍历判断(且和或)是否每一个元素或有一个元素怎么样
arr.reduce()和arr.reduceRight() 数组聚合迭代器从前或从后开始
arr.indexOf()和arr.lastIndexOf() 数组从左从右检索
Array.isArray(arr) 是否为数组
数组 VS 一般对象
都是对象,可以继承对象属性和方法
数组有length属性,数组比对象属性快
数组 VS 字符串
字符串类数组,有str.sharAt(x)按索引查找,也有length属性
六、函数和作用域
函数的概念:定义一次可调用多次的javascript代码段
创建函数:声明 function fuc(){} 声明前置
表达式 var fuc=function(){}
构造器 var fuc=new Function('a','b','console.log(a+b)')
全局this和一般函数的this
作为对象方法的函数的this
对象原型链上的this
get/set方法中的this
构造器中的this
call/apply方法中的this
bind方法中的this
函数属性 & arguments 实际参数(类数组对象)
闭包是指一个函数或函数的引用,与一个引用环境绑定在一起,这个引用环境是一个存储该函数每个非局部变量的表。
js没有块级作用域,只有函数作用域,并且具有作用域链机制
利用函数作用域封装函数
教程笔记《JavaScript深入浅出》的更多相关文章
- JavaScript深入浅出6-函数和作用域
慕课网教程视频地址:Javascript深入浅出 函数的概念:定义一次可调用多次的javascript代码段 创建函数:声明 function fuc(){} 声明前置 表达式 var fuc= ...
- JavaScript深入浅出5-数组
慕课网教程视频地址:Javascript深入浅出 数组:值的有序集合 创建数组:字面量,构造器new array() 数组的读写:push() 尾部加入新元素 unshift() 头部加入新元素 po ...
- JavaScript深入浅出4-对象
慕课网教程视频地址:Javascript深入浅出 对象的结构:包含一系列无序的属性,每个属性都有字符串key和对应的值 创建对象:对象字面量.new/原型链.Object.create 对象的属性操作 ...
- JavaScript深入浅出3-语句
慕课网教程视频地址:Javascript深入浅出 程序由语句组成,语句遵守特定语法规则 块 block {} 没有块级作用域 声明 var 异常 try catch finally 函 ...
- JavaScript深入浅出2-表达式和运算符
慕课网教程视频地址:Javascript深入浅出 表达式是指能计算出值的任何可用程序单元 原始表达式:常量.直接量 3.14,“test” 关键字 null,this 变量 i,k,j 表达式含:原始 ...
- JavaScript深入浅出1-数据类型
慕课网教程视频地址:Javascript深入浅出 javascript是弱数据类型语言,不需要显式的定义类型,一共有如下六种数据类型 原始类型:number string boolean null u ...
- jQuery官方基础教程笔记(转载)
本文转载于阮一峰的博文,内容基础,结构清晰,是jquery入门不可多得的资料,非常好,赞一个. 阮一峰:jQuery官方基础教程笔记 jQuery是目前使用最广泛的javascript函数库. 据统计 ...
- RX编程笔记——JavaScript 获取地理位置
RX编程笔记——JavaScript 获取地理位置 2016-07-05
- 函数原型属性-JavaScript深入浅出(三)
前两次总结了JavaScript中的基本数据类型(值类型<引用类型>,引用类型<复杂值>)以及他们在内存中的存储,对内存空间有了一个简单的了解,以及第二次总结了this深入浅出 ...
- 原型那些事 - JavaScript深入浅出(三)
前两次总结了JavaScript中的基本数据类型(值类型<引用类型>,引用类型<复杂值>)以及他们在内存中的存储,对内存空间有了一个简单的了解,以及第二次总结了this深入浅出 ...
随机推荐
- Django之Form组件归类
目录: Django内置字段 Django内置插件 常用选择插件 创建Form类时,主要涉及到 [字段] 和 [插件],字段用于对用户请求数据的验证,插件用于自动生成HTML; Field requi ...
- 题解 P1004 方格取数
传送门 动态规划Yes? 设i为路径长度,(为什么i这一维可以省掉见下)f[j][k]表示第一个点到了(j,i-j),第二个点到了(k,j-k) 则 int ji=i-j,ki=i-k; f[j][k ...
- D-温暖的签到题
链接:https://ac.nowcoder.com/acm/contest/892/D 题意: 给你一个长度为n的序列,初始为1,2,3...n,对其进行m次操作. 操作有两种: 1 l r 表示 ...
- NETCORE MVC模块化
NETCORE MVC模块化 ASP.NETCORE MVC模块化编程 前言 记得上一篇博客中跟大家分享的是基于ASP.NETMVC5,实际也就是基于NETFRAMEWORK平台实现的这么一个轻量级插 ...
- (转)Linux Network IO Model、Socket IO Model - select、poll、epoll
Linux Network IO Model.Socket IO Model - select.poll.epoll 原文:https://www.cnblogs.com/LittleHann/p/ ...
- Azkaban2.5安装部署(系统时区设置 + 安装和配置mysql + Azkaban Web Server 安装 + Azkaban Executor Server安装 + Azkaban web server插件安装 + Azkaban Executor Server 插件安装)(博主推荐)(五)
Azkaban是什么?(一) Azkaban的功能特点(二) Azkaban的架构(三) Hadoop工作流引擎之Azkaban与Oozie对比(四) 不多说,直接上干货! http://www.cn ...
- jquery的$().each和$.each的区别
在jquery中,遍历对象和数组,经常会用到$().each和$.each(),两个方法.两个方法是有区别的,从而这两个方法在针对不同的操作上,显示了各自的特点. $().each,对于这个方法,在d ...
- 【翻译转载】【官方教程】Asp.Net MVC4入门指南(3):添加一个视图
3. 添加一个视图 · 原文地址:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/adding-a-vi ...
- Mysql order by 排序 varchar 类型数据
Mysql order by 排序 varchar 类型数据 varchar 类型字段排序, 会將数字当成字符串来处理. 排序规则一般是从左到右一位位来比较. +0之后 就转化成INT 类型排序 ...
- AES加密示例
最近用到对文本内容进行加密,于是查了一下常用的加密算法: DES(Data Encryption Standard):对称算法,数据加密标准,速度较快,适用于加密大量数据的场合:3DES(Triple ...