引用类型 和 类
不是一个概念
用typeof来检测属性是否存在
typeof args.name == "string" 
需要实验
访问属性的方法
.号和[]
一般情况下要用.
判断是否是数组
Array.isArray( a ) 
数组变字符串
array.join("||") ;
重排序
reverse sort
sort( compare ) 
 
function compare(a, b){
   if( a > b ) return 1 
}
前端大于后值,return 1,则升序排列
连接 数组
concat()
slice()
不影响原数组,返回的是新生成的数组
splice()
可删 可插 替换
返回被删除的数组
位置方法
indexOf lastIndexOf
迭代方法 
有两个参数  方法 和 this
方法有三个参数 item index list
迭代方法有哪些
判断
some
every
 
过滤
filter
 
覆盖
map     返回新数组
forEach  直接对原数组操作 无返回值
归并方法
reduce 和 reduceRight
有两个参数  方法 和 归并基础的初始值
方法有上个参数  lastOne thisOne index list
Date方法
Date.parse() 把格式化的转成毫秒数
Date.UTC(年,月,日,时,分,秒)转成毫秒数
Date.now() 取得当前毫秒数
日期格式化
调用 toString() 即可
日期的方法
getFullYear getMonth getDate getDay getHours getMinutes getSeconds 
RegExp类型
/.at/匹配所有以at结尾的3个字符的组合 不区分大小写
捕获组
记住用法
exec
即使设置了g,  每次也只返回一个新的匹配
test
返回的是 布尔值
函数内部两属性
arguments this
arguments有callee 指向函数
函数的两个属性
length   函数希望接收到的命名参数个数
prototype 这个属性不可被枚举 ,用于保存所有实例方法
apply 和 call 的区别
参数以数组的形式传给apply的第二个参数
在用call时,传递给函数的参数必须逐个列举出来
bind
bind() 这个方法会创建一个函数的实例,其this值会被绑定到传给bind()函数的值
让数值显示指定的小数位
num.toFixed( 2 ) 
trim
删除前置和后置的空格
大小写转换
toLowerCase toUpperCase
字符串的方法中 和 正则相关的
String.match( Reg )  返回所有符合的
String.search( Reg )  永远是从字符串的开关向后查找模式
String.replace( Reg ) 可全局替换
 
通过一些特殊符号,可返回最近一次匹配结果中的内容
var text = "cat bat sat"
result = text.replace(/(.at)/g, "word ($1)" );
答案是 word(cat) word(bat) word(sat) 
即可以返回第一个捕获组的值
replace方法的第二个参数也可以是一个函数
text.replace( /[<>"&]/g, function( match,pos,originalText){ } ) 
match是模式的匹配项
pos是模式匹配项在字符串中的位置
originalText是原始字符串
 
如果正则定义了多个捕获组,那么上面那个function里的参数是
( match0,match1,match2,match3,pos,originalText) ;
 split( a, b ) ;
把字符串转化为数组
b表示数组的最大长度
单体内置对象
不依赖于宿主环境 在程序执行之前已经存在的 比如Global 和 Math
Global 
isNaN isFinite parseInt parseFloat 全是Global的方法
encodeURI  decodeURI
 
encodeURIComponent decodeURIComponent
对整个url编码
 
对url query里的查询参数编译
eval
把字符串变成表达式 ,请慎用
window Global
js里的window扮演了EcmaScript规定的Global对象的角色外,还承担了很多别的任务

读书笔记 - js高级程序设计 - 第五章 引用类型的更多相关文章

  1. 读书笔记 - js高级程序设计 - 第十一章 DOM扩展

      对DOM的两个主要的扩展 Selectors API HTML5  Element Traversal 元素遍历规范 querySelector var body = document.query ...

  2. 读书笔记 - js高级程序设计 - 第七章 函数表达式

      闭包 有权访问另一个函数作用域中的变量的函数 匿名函数 函数没有名字 少用闭包 由于闭包会携带包含它的函数的作用域,因此会比其它函数占用更多的内存.过度使用闭包可能会导致内存占用过多,我们建议读者 ...

  3. 读书笔记 - js高级程序设计 - 第六章 面向对象的程序设计

      EcmaScript有两种属性 数据属性 和 访问器属性 数据属性有4个特性 Configurable Enumerable Writable Value   前三个值的默认值都为false   ...

  4. 读书笔记 - js高级程序设计 - 第四章 变量 作用域 和 内存问题

      5种基本数据类型 可以直接对值操作 判断引用类型 var result = instanceof Array 执行环境 每个执行环境都有一个与之关联的变量对象,环境中定义的所有变量和函数都保存在这 ...

  5. 读书笔记 - js高级程序设计 - 第三章 基本概念

    启用严格模式 "use strict" 这是一个 pragma 编译指示 让编码意图更清晰  是一个重要原则 5种简单数据类型 Undefined Null Boolean Num ...

  6. 读书笔记 - js高级程序设计 - 第十五章 使用Canvas绘图

    读书笔记 - js高级程序设计 - 第十三章 事件   canvas 具备绘图能力的2D上下文 及文本API 很多浏览器对WebGL的3D上下文支持还不够好   有时候即使浏览器支持,操作系统如果缺缺 ...

  7. 读书笔记 - js高级程序设计 - 第十二章 DOM2和DOM3

      Node类型的变化   访问元素的样式 myDiv.style.backgroundColor = "red" myDiv.style.width = "100px& ...

  8. 读书笔记 - js高级程序设计 - 第十章 DOM

      文档元素 是文档的最外层元素,在Html页面中,文档元素始终都是<html>元素 在xml中,任何元素都可以是文档元素 Node类型 Node.ELEMENT_NODE 元素 Node ...

  9. 读书笔记 - js高级程序设计 - 第八章 BOM

      BOM的核心对象是window 它表示浏览器的一个实例,在浏览器中,window对象有双重角色,它既是通过js访问浏览器窗口的一个接口,又是ECMAScript规定的Global对象,这意味着在网 ...

随机推荐

  1. Metasploit学习笔记——环境配置

    <Metasploit渗透测试魔鬼训练营>书56页开始配置网络环境,一共五台机器,攻击机换成了自己更常用的kali,配置方法和back track相同. kali(攻击机) 10.10.1 ...

  2. 123.ModelForm的使用

    ModelForm 在我们的实例中,需要通过models.py中定义相关的模型字段,之后在forms.py中同样需要定义每个字段进行相应的验证,这样的话,我们会需要重复定义,这样的话,就相对比较麻烦, ...

  3. [转]SparkSQL – 有必要坐下来聊聊Join

    转载自网易范欣欣http://hbasefly.com Join背景介绍 Join是数据库查询永远绕不开的话题,传统查询SQL技术总体可以分为简单操作(过滤操作-where.排序操作-limit等), ...

  4. H5端js实现图片放大查看-插件photoswipe的使用

    这个是一个不知道什么鬼的东西,按照他需求改的,我也不知道对不对...看介绍说是h5把,我这个是用那个插件photoswipe的实现的 demo包地址: https://files-cdn.cnblog ...

  5. Educational Codeforces Round 65 选做

    好久没更博客了,随便水一篇 E. Range Deleting 题意 给你一个长度为 \(n\) 的序列 \(a_1,a_2,\dots a_n\) ,定义 \(f(l,r)\) 为删除 \(l\le ...

  6. a标签-伪类

    a:link {color: #FF0000} /* 未访问的链接 */ a:visited {color: #00FF00} /* 已访问的链接 */ a:hover {color: #FF00FF ...

  7. POJ 3007:Organize Your Train part II

    Organize Your Train part II Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7561   Acce ...

  8. POJ1014:Dividing

    Dividing Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 63013   Accepted: 16315 Descri ...

  9. mapper.xml实现oracle的分页语句

    当我们用常规方法进行分页查询时,虽然在数据库可以分页查询出来数据, 如下语句 <!-- 分页查询所有 --> <select id="findAllPage" r ...

  10. 127个常用的JS代码片段,每段代码花30秒就能看懂(上)

    127个常用的JS代码片段,每段代码花30秒就能看懂(上) JavaScript 是目前最流行的编程语言之一,正如大多数人所说:“如果你想学一门编程语言,请学JavaScript.” FreeCode ...