JavaScript杂记(3)

1 对象   (无序的数据集)

     由若干个“键值对”(key-value)构成。

var a={name:xxx};

name--->key (键名)    xxx--->value(键值)

name不用引号就是标识名,加了引号就是字符串。

大括号就定义了一个对象,它被赋值给变量a.


生成空对象
等价于下图

1.1 键名

①对象的所有键名都是字符串,所以加不加引号都可以。

②如果键名不符合标识名的条件(比如第一个字符为数字,或者含有空格或运算符),也不是数字,则必须加上引号。

③JavaScript的保留字可以不加引号当作键名(为了ie兼容,不要用保留字)。

④如果键名是数字,则会默认转为对应的字符串。键名为数值,则会先转为标准形式的数值,然后再转为字符串。

1.2 属性

对象的每一个“键名”又称为“属性”(property),它的“键值”可以是任何数据类型。如果一个属性的值为函数,通常把这个属性称为“方法”,它可以像函数那样调用。

字符串不是变量,是常量。

1.2.1 读取属性

读取对象的属性,有两种方法,一种是使用点运算符,还有一种是使用方括号运算符。

varo={p:'Hello World'};

①o.p// "Hello World"

②o['p']// "Hello World


如果使用方括号运算符,键名必须放在引号里面,否则会被当作变量处理。但是,数字键可以不加引号,因为会被当作字符串处理。方括号运算符内部可以使用表达式。

数值键名不能使用点运算符(因为会被当成小数点),只能使用方括号运算符。

1.2.2检查变量是否声明

①如果变量没有声明,会报错。属性没声明,会返回undefined.

②全局变量都是window的属性。(不写var的变量时全局变量。)

全局变量

检测object有没有a属性

①if (object.a===undefined){xxx};

②if('a' in object){xxx};         不能用变量a,要用字符串a.


检测全局变量


对象删除

1.3 JSON (javaScript object Notation) --标记法

用字符串表示标记法,json不能表示函数。

json语法详解

json对象:

①'{}'

②'{"name":1}'

json语法是js语法的子集。想传播有结构信息可以用json语法。

例:1、function

{a=function(){}}      --不能当json

       2、{'a':1}       --不是合法的json语法(没用双引号)

遍历


2 数组  (有序的数据集)--是一种对象。

 ①var array=[    ]

 ②var array=new Array()


2.1 数组值

 数组的值可以是任意值。可以是对象也可以不是对象。

2.2 length属性

数组的length属性,返回数组的成员数量.

数组与对象的区别:

①数组多了一个length属性。

②是有序的。

③key是0、1、2、3.....(字符串)。

遍历

数组调用方法:MDN



3 函数 --也是一种对象。(输入参数与输出参数的映射关系)

函数就是一段预先设置的代码块,可以反复调用,根据输入参数的不同,返回不同的

3.1 函数的声明

(1)function命令

function 函数名(输入参数,输入参数){console.log(输入参数,输入参数);}

(2)函数表达式

除了用function命令声明函数,还可以采用变量赋值的写法。

var  print=function(输入参数,输入参数){console.log(输入参数,输入参数);}

(3)Function构造函数

还有第三种声明函数的方式:Function构造函数。

```

var add=new Function ('x','y','return (x + y)');

// 等同于

function add(x,y){return(x+y);}

```

在上面代码中,Function构造函数接受三个参数,除了最后一个参数是add函数的“函数体”,其他参数都是add函数的参数。如果只有一个参数,该参数就是函数体。

3.2声明的赋值


整体提升


部分提升



函数赋值


函数的返回值

行参的作用:给实参起名字。

length是形参的个数。


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容