专栏首页小古哥的博客园教程笔记《JavaScript深入浅出》

教程笔记《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没有块级作用域,只有函数作用域,并且具有作用域链机制

利用函数作用域封装函数

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JS数组去重的三种方法

    在程序中,通常解决一个问题的方法有很多种。当然这些不同思路的解决方法,在性能和效率上也有很大差异。 以下是数字去重的三种方法, 一、循环遍历法(传统思路) 最简...

    小古哥
  • 读书笔记《PHP与MySQL程序设计》一

    第1章 PHP概述 1.1  历史(PHP4、PHP5、PHP5.3、PHP6[未发布]) 1.2 一般语言特性(实用性、强大功能、可选择性、成本[开源]) 第...

    小古哥
  • 基于jquery的-获取短信验证码-倒计时

    在制作短信验证的时候,需要做一个获取短信按钮,点击后显示倒计时, html代码如下: 1 <input class="gain" type="button" v...

    小古哥
  • 构建不重复特殊数组

    原理非常简单,set 里面是不能有重复内容的。所以先转成 set 再转成 list 即可实现去重。

    FungLeo
  • 博客通用版Live2d伊斯特瓦尔发布

    Typecho插件版:Typecho插件版之给博客加上能陪聊的Live2d版伊斯特瓦尔

    小仙女闯运维
  • 嵌套数组的合并,扁平化数组

    对于 [ [], [], [], ...] 数组里嵌套数组,有个需求:将里面的数组元素都放到外层数组,变成 , , , ...

    Krry
  • 3 CPU缓存一致性协议MESi

       然后加载元数据区的方法, 比如refresh()方法. 启动线程后, 首先, 会在线程栈开辟一块栈帧, 然后执行操作数栈  

    用户7798898
  • python在Keras中使用LSTM解决序列问题

    时间序列预测是指我们必须根据时间相关的输入来预测结果的问题类型。时间序列数据的典型示例是股市数据,其中股价随时间变化。

    拓端
  • 稳扎稳打JavaScript(三)——创建对象的几种方式

    有了前面两篇文章的基础后,我们来谈一谈在JS中创建对象的几种方式。 建议大家先预习下先前的两篇博客: 稳扎稳打JavaScript(一)——作用域链 ...

    大闲人柴毛毛
  • java高并发系列 - 第13天:JUC中的Condition对象

    Object对象中的wait(),notify()方法,用于线程等待和唤醒等待中的线程,大家应该比较熟悉,想再次了解的朋友可以移步到java高并发系列 - 第6...

    路人甲Java

扫码关注云+社区

领取腾讯云代金券