javacript笔记
根据EC5.0
一共有六种数据类型:
number,string,bool
undefine,null
object(广义的) --->object(狭义的),array,function

前五种叫primitive type,最后一种是complex object
三种判断对象类型的方法:
typeof,instanceof,Object.prototype.toString

typeof 前三类型就是基本类型
typeof undefined 是undefined
typeof null 是 object //因为历史的原因,为了兼容以前的代码,并不表示null是对象
typeof [] 是object

null和undifined的区别:
null表示空值
undefined表示不存在值

实际上,所有数据,都可以被看作广义的对象,或说用对象方式调用
var s = new String("123");//s是object
这六个值是false:undefined,null,0,"",false,NaN

自动分号添加:javascript引擎

错误类型:
最一般的错误类型Eooro
六种错误类型
SystaxError
Reference Error
RangeError
TypeError
URIError
EvalError //EC5中不再出现

函数:
三种声明函数的方法
1、function命令
function print(s) {
console.log(s);
}
2、函数表达式 赋值变量
var print=function(s){
console.log(s);
}
function后不应加函数名,如果加了,只在函数内部有效
3、Function构造函数 //很少人使用
var print=new Function("s","console.log(s)"); //最后一个参数是函数体,之前的参数如果存在,则是函数的参数
var print=Function("s","console.log(s)");

作为第一等公民:函数可以作为其他数据类型一样使用,如可以将函数名赋值给变量和对象的属性,也可以当作参数传入其他函数,或者作为函数的结果返回。也因此,函数会像变量声明一样,获得提升。
使用赋值变量的方式声明函数,会导致,先声明,后赋值。也就是说,变量是提升了,但还未赋值。 因此,当同一个函数使用function命令和变量赋值的方式同时声明的话,js引擎总是会认定赋值语句的定义。
var f = function() {
console.log('1');
}

function f() {
console.log('2');
}

f() // 1

按照ECMA规范,不能在非函数中声明函数,但实际傻瓜,很多浏览器可以运行。但又因为变量提升,本意图使用条件语句判断是否声明,实际上没有效果。因此,要达到条件语句的效果,只能使用函数表达式

函数的属性:
name:函数的名称
length 函数的参数个数

作用域:
区块block本身不构成作用域,因此{}只是用于for,if,while,function等语法结构
因此,作用域只分为两种:全局作用域和函数作用域。

函数作用域内的变量会覆盖全局变量
函数作用域内的变量也同样存在变量提升的现象
函数的参数可以省略,若省略,则其值为undefined

关于传值和传址:
在C#中,如果传递的参数是原始类型(int,float等)或结构体(struct),那么就是传值调用。
如果传递的参数是类(class)那么就是传引用调用。(但是当函数内部给对象整体做改变时,那么,仍旧是传值)
如果传递的参数前有ref或者out关键字,那么就是传引用调用。
在JS中,前两条同样成立。当然,这里的对象是指广义的,即包括对象,函数和数组。

arguments[]对象包含了函数运行时的所有参数
但是arguments虽然很像数组,其实不是数组,而是对象- -! 因此数组的方法如slice和foreach
slice(i,j)方法,如果是数组使用,则从i位置,切割到j位置,返回新的子数组,原先的数组不变。
如果是string使用,也是返回一个新的子字符串,原先的字符串不变。

js学习笔记的更多相关文章

  1. js学习笔记<拷贝传值,引用传址和匿名函数>

    拷贝传值:把一个变量的值拷贝一份,传给了另外一个变量拷贝传值中,两个变量之间没有任何联系,修改其中一个一个变量的值,原来的变量不变. 例: var arr1 = ["张三",24, ...

  2. Js 赋值传值和引用传址

    赋值传值和引用传址 在JavaScript中基本数据类型都是赋值传值,复合数据类型都是引用传址(传地址) 基本数据类型的变量名和数据是直接存在"快速内存"(栈内存)中,而复合数据类 ...

  3. 图解JS的传值与传址

    //编程过程中经常会碰到传值,传址的问题!今天的主题就是关于传值.与传址. //先讲讲赋值操作 //下例是原始类型赋值操作 var a=1,b=a,a=2; console.log("a=& ...

  4. 再谈js传值和传址

    js的传值和传址还是真绕,前回文说道 1.值类型是传值的 2.对象和数组是传址的 这两点通过例子的到了证实 然而还有一种情况没有讨论 即 函数的参数的传值和传址 通过实验,在函数中用一个新对象去覆盖传 ...

  5. JS 学习笔记--9---变量-作用域-内存相关

    JS 中变量和其它语言中变量最大的区别就是,JS 是松散型语言,决定了它只是在某一个特定时间保存某一特定的值的一个名字而已.由于在定义变量的时候不需要显示规定必须保存某种类型的值,故变量的值以及保存的 ...

  6. JAVA传值与传址

    要了解JAVA中的传值与传址问题,必要先要了解JVA中的栈内存和堆内存,>>>>点些查看<<<<昨天写的学习记录 栈:基本数据类型.数据的引用变量,这两 ...

  7. javascript . 05 json的组成、for...in 遍历对象、简单数据类型与复杂数据类型的传值与传址、内置对象

    对象字面量  JSON var obj = { aaa :999}; var json={"aaa":999,"bbb":888}; "kay&quo ...

  8. Python 传值和传址 copy/deepcopy

    传值:被调函数局部变量改变不会影响主调函数局部变量 传址:被调函数局部变量改变会影响主调函数局部变量 Python参数传递方式:传递对象引用(传值和传址的混合方式),如果是数字,字符串,元组则传值:如 ...

  9. 【转】Backbone.js学习笔记(二)细说MVC

    文章转自: http://segmentfault.com/a/1190000002666658 对于初学backbone.js的同学可以先参考我这篇文章:Backbone.js学习笔记(一) Bac ...

随机推荐

  1. UML入门

    本文主要讲解uml的一些入门知识. uml:统一建模语言,uml通过图形化的表达对系统进行细致的划分,在开发前期有助于开发人员与开发人员之间交流,同时也能方便用户与开发者之间进行良好的反馈.利用uml ...

  2. Oracle:试图访问正在使用的事务临时表

    处理步骤为 1.找到表ID select * from dba_objects where object_name like 'TPT_RPWORPA1_QRY' 2.通过表ID查找正在使用的事务 s ...

  3. rabbitmq

    send端 import pika credentials = pika.PlainCredentials(') connection = pika.BlockingConnection(pika.C ...

  4. Redis-Cluster实战--5.使用redis-cli安装

    Redis-Cluster实战--.使用redis-cli安装 博客分类: redis 缓存 redis-cluster redisCluster指派槽cluster-infomeetslots 转载 ...

  5. Node.js配合node-http-proxy解决本地开发ajax跨域问题

    情景: 前后端分离,本地前端开发调用接口会有跨域问题,一般有以下3种解决方法: 1. 后端接口打包到本地运行(缺点:每次后端更新都要去测试服下一个更新包,还要在本地搭建java运行环境,麻烦) 2. ...

  6. Windows Server 2012 R2桌面化详细设置图解

    一.任务栏左下角启动服务器管理器,然后进行设置. 1.登录不显示服务器管理器 2.本地服务器,看到右边的IE增强的安全配置,如图所示,关闭两项内容.这样就关闭了IE增强安全提示框. 3.“工具”菜单, ...

  7. CentOS 7合盖后黑屏但不进入睡眠模式修改

    CentOS 7合盖后黑屏但不进入睡眠模式修改 systemd 能够处理某些电源相关的 ACPI事件,你可以通过从 /etc/systemd/logind.conf 以下选项进行配置: HandleP ...

  8. 高可用thrift客户池的实现详解

    最近,公司要求将组内的thrift客户端组件推广至公司内使用.基本的要求如下: 1.高可用 2.集成名称服务,也就配置文件支持服务发现 3.解耦,客户端和高可用组件解耦,简单来说就是,如果以后要切换其 ...

  9. ecshop 不同页面调用不同分类文章的解决办法

    调用文章列表,需要修改对应的程序,修改index.php或者arctical_cat.php文件在$smarty->assign('new_articles', index_get_new_ar ...

  10. Mac php使用gd库出错 Call to undefined function imagettftext()

    第一次在Mac下使用ThinkPHP,用到验证码功能时报如题的错误: Call to undefined function Think\imagettftext() 然后检查自己的GD库,发现安装上了 ...