JS基础(二)


2018.05.13

11.JavaScript 对象

JavaScript对象是拥有属性和方法的数据,几乎所有的事物都是对象。

JavaScript对象是属性变量的容器。

JavaScript对象创建常见两种:
第一种,对象由花括号分隔。在括号内部,对象的属性以名称和值对的形式(name: value) 来定义。推荐使用这种方式。

var person={
  firstname : "John",
  lastname  : "Doe",
  id        :  5566
};

第二种,先创建对象,再追加属性和方法。

var person = new Object();
person.firstname = "John";
person.lastname = "Doe";
person.id = 5566;

另外,对象属性有两种寻址方式:

name = person.lastname;  //这种用法比较常见
name = person["lastname"];

12.JavaScript 函数

函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块。

语法是,关键词function + 方法名() + { } ,花括号中间的就是函数。

在调用函数时,可以向其传递参数,参数之间由英文逗号分隔。

当声明函数时,同时把参数作为变量来声明:

function myFunction(var1, var2) { }

13. JavaScript 变量的生存期

JavaScript 变量的生命期从它们被声明时初始化。

局部变量会在函数运行以后被删除。

全局变量会在页面关闭后被删除。

14. JavaScript 作用域

作用域是可访问变量的集合。

在JavaScript中,作用域为可访问变量,对象,函数的集合。

HTML中的全局变量:window对象,所有数据变量都属于window对象。

15. JavaScript 事件

HTML 事件是发生在HTML元素上的事情。

当在HTML 页面中使用JavaScript 时,JavaScript 可以触发这些事件。

常见的HTML事件:

事件 描述
onchange HTML 元素改变
onclick 用户点击 HTML 元素
onmouseover 用户在一个HTML元素上移动鼠标
onmouseout 用户从一个HTML元素上移开鼠标
onkeydown 用户按下键盘按键
onload 浏览器已完成页面的加载

16. JavaScript 字符串

JavaScript 字符串用于存储和处理文本。

字符串索引从 0 开始。

注意: 不要创建 String 对象。它会拖慢执行速度,并可能产生其他副作用。

17. JavaScript switch 语句

switch 语句用于基于不同的条件来执行不同的动作。
语法:

switch(n)
{
    case 1:
        执行代码块 1
        break;
    case 2:
        执行代码块 2
        break;
    default:
        与 case 1 和 case 2 不同时执行的代码
}

工作原理:首先设置表达式 n(通常是一个变量)。随后表达式的值会与结构中的每个 case 的值做比较。如果存在匹配,则与该 case 关联的代码块会被执行。请使用 break 来阻止代码自动地向下一个 case 运行。


2018.05.15

18.JavaScript typeof 操作符

可以使用 typeof 操作符来检测变量的数据类型,

typeof "John"                 // 返回 string 
typeof 3.14                   // 返回 number
typeof NaN                    // 返回 number
typeof false                  // 返回 boolean
typeof [1,2,3,4]              // 返回 object
typeof {name:'John', age:34}  // 返回 object
typeof new Date()             // 返回 object
typeof function () {}         // 返回 function
typeof myCar                  // 返回 undefined (如果 myCar 没有声明)
typeof null                   // 返回 object
console.log(typeof "John");   //输出:string 

注意:

  • NaN 的数据类型是 number;
  • 数组(Array)的数据类型是 object;
  • 日期(Date)的数据类型为 object;
  • null 的数据类型是 object;
  • 未定义变量的数据类型为 undefined;

19.JavaScript 的null 和 undefined

null是一个值的特殊类型, undefined 是未经初始化的默认值。初始化的过程就是给变量赋一个值。

无论什么情况下,都没有必要把一个变量的值显式的设置成undefined。
但null不是,换句话说, 只要意在保存对象的变量还没有真正保存对象,就应该明确地让该变量保存 null 值。
这样做不仅可以 体现 null 作为空对象指针的惯例,而且也有助于进一步区分 null 和 undefined。

null 和 undefined 值相等,但类型不同。

typeof undefined             // undefined
typeof null                  // object
null === undefined           // false
null == undefined            // true

注意:==先转换类型再比较,===先判断类型,如果不是同一类型直接为false。


2018.05.15

20. JavaScript 变量提升

变量提升:JavaScript 中,函数声明和变量声明总是会被解释器悄悄地被"提升"到方法体的最顶部,但初始化不会被提升。

JavaScript 中,变量可以在使用后声明,也就是变量可以先使用再声明。

对于大多数程序员来说并不知道JavaScript的变量提升,通常做法是在每个作用域开始前声明变量,这也是正常的 JavaScript 解析步骤。

21. JavaScript 严格模式

在脚本或函数的头部添加 "use strict"; 表达式来声明。目的是为了规范代码减少隐患,提高编译器效率。

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

推荐阅读更多精彩内容