JS作用域是基于词法作用域的顶级对象。

JS是一门弱类型语言,强类型能在编译时检测错误。

JS是唯一一门所有浏览器都能识别的语言。

块注释对于被注释的代码是不安全的,例如/*  var rm=/a*/.match(s);  */

JS只有一个数字类型,没有分离出整数类型,完全避免了短整型的溢出问题。

NaN不等于任何值,包括他自己。

JS所有字符都是16位。

JS允许数组包含任意类型的值。

字符串是不可变的,一旦被创建,永远无法改变它,但是可以通过+运算符连接其他字符串来创建一个新字符串。

2个包含着完全相同的字符且字符顺序也相同的字符串被认为是相同的字符串,所以'c'+'a'==='ca'是true

switch,while,for,do语句配合break语句来使用。

falsy的值:

  • false
  • null
  • undefined
  • 空字符串''
  • 数字0
  • 数字NaN

其他都被当做真。

for in会枚举一个对象的所有属性名(键名),需要object.hasOwnProperty(variable)来确定这个属性名是该变量对象的成员还是来自原型链。

do在代码块执行后再检测,while在执行前检测。

+运算符可以进行加法运算或字符串连接。如果想加法运算,两个运算数都得是数字。

如果第1个运算数的值为假,运算符&&产生第1个运算数的值,否则产生第2个运算数的值。

如果第1个运算数的值为真,运算符||产生第1个运算数的值,否则产生第2个运算数的值。

JS简单数据类型包括数字,字符串,布尔值,null值,undefined值,其他所有的值都是对象。

检索方式:

  • []
  • .(优先考虑)

如果字符串是合法的JS标识符且不是保留字,那么也可以用.来检索。

||可以填充默认值:var middle=stooge["middle-name"]||"(none)";

对象里的值可以通过赋值语句来更新,如果属性名已存在对象里,那么这个属性的值就会被替换。如果对象之前没有那个属性名,那么该属性就扩充到对象中。

Object.create()可以创建一个使用原对象作为其原型的新对象。

delete运算符可以用来删除对象的属性。如果对象包含该属性,那么该属性会被移除。它不会触及原型链中的任何对象。删除对象的属性可能会让来自原型链中的属性透显出来。

对象字面量产生的对象连接到Object.prototype。函数对象连接到Function.prototype。每个函数在创建时会附加2个隐藏属性:函数上下文和实现函数的代码。

当实参的个数>形参的个数,超出的参数值被忽略。

当实参的个数<形参的个数,缺失的参数值被替换为undefined。

  1. 方法调用模式。就是一个函数被保存为对象的一个属性。当一个方法被调用时,this被绑定到该对象。this到对象的绑定发生在调用的时候。
  2. 函数调用模式。this被绑定到全局对象,可以通过定义一个变量that保存this。
  3. 构造器调用模式。如果在一个函数前面加上new来调用,会创建一个连接到该函数的prototype成员的新对象,同时this被绑定到那个新对象上。
  4. apply调用模式。apply接收2个参数,第1个是要绑定给this的值,第2个是一个参数数组。

当函数被调用,可以通过arguments数组来访问到所有它被调用时传递给它的参数列表。(包括实参>形参,超出的实参)

throw语句中断函数的执行,它会抛出一个exception对象,该对象包含一个用来识别异常类型的name属性和message属性。这个exception对象会被传递到try的catch从句。

var add=function (a,b){

throw{

name:'TypeError',

message:'add needs numbers'

};

}

var try_it=function(){

try{

add('7');

}cache(e){

document.write(e.name+':'+e.message);

}

}

移除首尾空格的方法:

String.method('trim',function(){

return this.replace(/^\s+|\s+$/g,'');

}

要确定没有该方法时才添加方法:Function.prototype.method=function(name,func){}

使用函数和闭包来构造模块。

级联可以在一个语句中一次调用同一个对象的很多方法。A.().B().C()

柯里化(局部套用),把多参数函数转换为一系列单参数函数并进行调用的技术。

记忆:将先前的操作结果记录在某个对象里,避免无谓的重复计算。比如斐波那契数列。

优化前:

var fib=function(n){

return n<2?n:fib(n-1)+fib(n-2);

}

for(var i=0;i<=10;i++){

console.log(fib(i));

}

优化后:

var memoizer=function(memo,formula){

var fib=function(n){

var result=memo[n];

if(typeof result !=='number'){

result=fib(n-1)+fib(n-2);

memo[n]=result;

}

return result;

};

return fib;

};

var fibb=memoizer([0,1],function(fib,n){

return fib(n-1)+fib(n-2);

});

当一个函数对象被创建时,构造器产生的函数对象赋予一个prototype属性,它的值是一个包含constructor属性且属性值为该新函数的对象。

用new调用一个函数时,函数执行方式:1.创建一个新对象,继承自构造器函数的原型对象 2.调用构造器函数,绑定this到新对象上 3.如果它的返回值不是一个对象,就返回该新对象。

差异化继承:

var myMammal={

name:'hello',

get_name:funcrion(){

return this.name;

},

says:function(){

return this.saying||'';

}

}

var myCat=Object.create(myMammal);

myCat.name='world';

myCat.saying='meow';

数组的长度length:length的属性值时这个数组的最大整数属性名+1,它不一定等于数组里的属性个数。arr[100001]=true; arr.length//100002

设置更大的length不会为数组分配更多的空间,设置更小的length会把>=新length的属性删除。

for in遍历无法保证顺序,而且在原型上加扩展方法会被for in出来。所以最好用hasOwnProperty()判断。

//    var arr={
    //        3:1,
    //        42:2,
    //        11:3
    //    }
    //    for(var key in arr){
    //        console.log(arr[key]);
    //    }
    Object.prototype.say='hello';
    var arr={
        "name":"zyy"
    }
    for(var key in arr){
        console.log(key+' '+arr[key]);
    }
判断是否是数组:
var is_arr=function(value){
 return value&&typeof value==='object'&&value.constructor===Array;
}
 
array.concat(item):包含一份array的浅拷贝并把参数附加其后。【不会修改array】
array.join(分隔符):先把array中每个元素构造成一个字符串,然后用分隔符把他们连接在一起。【速度比+更快】
array.pop():移除最后一个元素并返回,如果为空返回undefined。
array.push(item...):把参数附加到数组尾部【会修改array】
array.reverse():反转array里元素顺序,并返回array本身。
array.shift():移除数组第1个元素,并返回删除元素。如果空返回undefined。
array.slice(start,end):对array中的一段做浅拷贝,end可选。可以是负数。
array.sort():在比较时候会自动转为字符串类型,sort根据不同浏览器稳定性不一样。
array.splice(start,deleteCount,item...):
array.unshift(item...):把元素添加到数组头部。返回新length
 
number.toExponential():把number转成一个指数形式的字符串。
number.toFixed():转换成十进制形式的字符串。
number.toPrecision():
number.toString()
 
object.hasOwnProperty(name):如果object包含一个名为name的属性,返回true.原型链中同名属性不会被检查。
 
string.charAt(pos):返回在pos处的字符,返回的是个字符串。如果0<pos<string.length,返回空字符串
string.charCodeAt(pos):返回pos处的字符码位,如果0<pos<string.length,返回NaN
string.concat(string...):拼接字符串
string.indexOf(SearchString,pos):在string字符串查找searchString,返回匹配第一个字符的位置。pos可选。
string.lastIndexOf():类似
string.replace(searchValue,replaceValue):对string进行查找和替换,返回一个新字符串。
string.slice(start,end):同array
string.split(separator,limit):把string分割成片段创建一个字符串数组。limit限制被分割的片段数量。
string.toLowerCase():全小写
string.toUpperCase():全大写。
 
NaN===NaN返回false
NaN!==NaN返回true
 
 
==和!=如果两个运算数是不同的类型,它们就会试图转换值的类型。
'' == '0'  //false
0 == ''    //true
false == 'false'  //false
false == '0'    //true
false == undefined  //false
false == null //false
null == undefined //true
' \t\r\n ' == 0  //true
 
 

学习笔记——JS语言精粹的更多相关文章

  1. [java学习笔记]java语言核心----面向对象之this关键字

    一.this关键字 体现:当成员变量和函数的局部变量重名时,可以使用this关键字来区别:在构造函数中调用其它构造函数 原理:         代表的是当前对象.         this就是所在函数 ...

  2. [java学习笔记]java语言核心----面向对象之构造函数

    1.构造函数概念 特点: 函数名与类名相同 不用定义返回值类型 没有具体的返回值 作用:                给对象进行初始化 注意: 默认构造函数 多个构造函数是以重载出现的 一个类中如果 ...

  3. Java学习笔记:语言基础

    Java学习笔记:语言基础 2014-1-31   最近开始学习Java,目的倒不在于想深入的掌握Java开发,而是想了解Java的基本语法,可以阅读Java源代码,从而拓展一些知识面.同时为学习An ...

  4. IOS学习笔记07---C语言函数-printf函数

    IOS学习笔记07---C语言函数-printf函数 0 7.C语言5-printf函数 ------------------------- ----------------------------- ...

  5. IOS学习笔记06---C语言函数

    IOS学习笔记06---C语言函数 --------------------------------------------  qq交流群:创梦技术交流群:251572072              ...

  6. amazeui学习笔记--js插件(UI增强)--警告框Alert

    amazeui学习笔记--js插件(UI增强)--警告框Alert 一.总结 1.警告框基本样式:用am-alert声明div容器, <div class="am-alert" ...

  7. amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown

    amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown 一.总结 1.am-dropdown(及其孩子):控制下拉列表的样式 2.data-am-dropdown(及其孩子):控 ...

  8. amazeui学习笔记--js插件(UI增强3)--折叠面板Collapse

    amazeui学习笔记--js插件(UI增强3)--折叠面板Collapse 一.总结 注意点: 1.data-am-collapse:这个东西就是展开折叠事件 2.am-collapse(包括其下属 ...

  9. amazeui学习笔记--js插件(UI增强2)--按钮交互Button

    amazeui学习笔记--js插件(UI增强2)--按钮交互Button 一.总结 1.按钮loading状态: <button type="button" class=&q ...

随机推荐

  1. DDD(领域驱动设计)--战略设计

    领域 领域是一个组织所做的事情以及其中所包含的一切.商业机构通常会确定一个市场,然后在这个市场中销售产品和服务.每个组织都有它自己的业务范围和做事方式. 领域就是解决一个特定范围内的业务问题. 如何分 ...

  2. 阿里面试官:小伙子,你给我说一下JVM对象创建与内存分配机制吧

    内存分配机制   逐步分析 类加载检查: 虚拟机遇到一条new指令(new关键字.对象的克隆.对象的序列化等)时,会先去检查这个指令的参数在常量池中定位到一个类的符号引用,并且这个符号引用代表的类是否 ...

  3. 二叉堆python实现

    二叉堆是一种完全二叉树,我们可以使用列表来方便存储,也就是说,用列表将树的所有节点存储起来. 如下图,是小根堆方式的二叉堆,假设父节点的下标为p,则他的左孩子下标为2P+1,右孩子下标为2P+2 cl ...

  4. 最全总结 | 聊聊 Python 办公自动化之 Word(下)

    1. 前言 关于 Word 文档的读写,前面两篇文章分别进行了一次全面的总结 最全总结 | 聊聊 Python 办公自动化之 Word(上) 最全总结 | 聊聊 Python 办公自动化之 Word( ...

  5. 痞子衡嵌入式:在IAR开发环境下为工程开启CRC完整性校验功能的方法

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是在IAR开发环境下为工程开启CRC完整性校验功能的方法. CRC校验在嵌入式领域里的应用非常广,比如在通信领域,CRC检验值可以作为数据 ...

  6. php8.0正式版新特性和性能优化学习

    前言 PHP团队宣布PHP8正式GA(链接).php的发展又开启了新的篇章,PHP8.0.0版本引入了一些重大变更及许多新特性和性能优化机制.火速学习下~ JIT(Just in Time Compi ...

  7. MySql学习笔记--详细整理--下

    目录 索引 测试索引 索引原则 权限管理和备份 备份 规范数据库设计 三大范式 JDBC JDBC程序 Statement对象 工具类实现 sql注入 PreparedStatement对象 事务 数 ...

  8. C语言讲义——内存管理

    动态分配内存 动态分配内存,在堆(heap)中分配. void *malloc(unsigned int num_bytes); 头文件 stdlib.h或malloc.h 向系统申请分配size个字 ...

  9. 程序演示:C语言第一个简单实例

    在信息化.智能化的世界里,可能很早很早 我们就听过许多IT类的名词,C语言也在其中,我们侃侃而谈,到底C程序是什么样子?让我们先看简单的一个例子: 1 2 3 4 5 6 7 8 9 #include ...

  10. 【线程池】自己声明临时线程池一定要shutdown!

    场景: 某个定时任务需要多线程执行,执行时间较久且每天只跑一次,想单独拉出一个线程池和其他业务隔离开,交给spring会导致核心线程一直存在 浪费线程资源,因此想单独拉一个池子用完就丢,原本想的是,在 ...