JS基础(二)

2018-05-15  本文已影响0人  美美欣

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 

注意:

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"; 表达式来声明。目的是为了规范代码减少隐患,提高编译器效率。

上一篇下一篇

猜你喜欢

热点阅读