今天是我在乐字节学习的第13天

2020-11-10  本文已影响0人  乐学小乐

今天是我在乐字节教育学习的第13天,今天主要学习的内容是JavaScript基础语法之变量和数据类型

变量

​ 变量即一个带名字的用来存储数据的内存空间,数据可以存储到变量中,也可以从变量中取出数据。

变量的声明

​ JavaScript是一种弱类型语言,在声明变量时不需要指明数据类型,直接用var修饰符进行声明。

​ 变量声明和赋值:

// 先声明再赋值
var a ;    
a = 10;
// 声明同时赋值
var b = 20;

变量的注意点

(1)若只声明而没有赋值,则该变量的值为undefined。

var box;
console.log(box);

(2)变量要有定义才能使用,若变量未声明就使用,JavaScript会报错,告诉你变量未定义。

console.log(box2);

(3)可以在同一条var命令中声明多个变量。

var a, b, c = 10;
console.log(a,b,c);

(4)若使用var重新声明一个已经存在的变量,是无效的。

var box = 10
var box;

(5)若使用var重新声明一个已经存在的变量且赋值,则会覆盖掉前面的值

var box = 10;
var box = 25;

(6)JavaScript是一种动态类型、弱类型语言,也就是说,变量的类型没有限制,可以赋予各种类型的值。

var box = 'hello world';
box = 10;

变量提升

​ JavaScript 引擎的工作方式是,先解析代码,获取所有被声明的变量,然后再一行一行地运行。这造成的结果,就是所有的变量的声明语句,都会被提升到代码的头部,这就叫做变量提升。

console.log(msg);
var msg = "so easy";

// 变量提升,相当于下面的代码
var msg;
console.log(msg);
msg = "so easy";

// 说明: 最后的结果是显示undefined,表示变量msg已声明,但还未赋值。

​ 注意:变量提升只对 var 命令声明的变量有效,如果变量不是用 var 命令声明的,就不会发生变量提升。

console.log(msg);
msg = "error";

数据类型

​ 虽说JS是弱类型语言,变量没有类型,但数据本身是有类型的。针对不同的类型,我们可以进行不同的操作。

​ JavaScript 中有6 种数据类型,其中有五种简单的数据类型:UndefinedNull布尔数值字符串。一种复杂数据类型Object

数  值(Number): 整数和小数(比如 1 和 3.14)
字符串(String): 字符组成的文本(比如"Hello World")
布尔值(Boolean):true(真)和 false(假)两个特定值
Undefined:       表示“未定义”或不存在,即此处目前没有任何值
Null:            表示空缺,即此处应该有一个值,但目前为空
对象(object)(引用) : 各种值组成的集合
    1)、对象(object){name:”zhangsan”,age:”18”}
    2)、数组(array)[1,2,3]
    3)、函数(function)function test() {}

undefined

​ undefined类型的值是undefined。

​ undefined 是一个表示"无"的原始值,表示值不存在。

​ 出现undefined的常见情况:

​ (1)当声明了一个变量而没有初始化时,这个变量的值就是undefined

var box;
console.log(box); //undefined

​ (2)调用函数时,该函数有形参,但未提供实参,则该参数为undefined。

function noData(str) { // js函数形参只需要变量名即可
    console.log(str); // undefined
}
noData(); // 调用方法时,未传递参数

​ (3)函数没有返回值时,默认返回 undefined。

// 方法没有返回值
function noData() { 
    console.log("Hello"); 
}
var re = noData();// 定义变量接收无返回值的方法
console.log(re);

null

​ null类型是只有一个值的数据类型,即特殊的值null。它表示空值,即该处的值现在为空,它表示一个空对象引用。

​ 使用Null类型值时注意以下几点:

​ 1)使用typeof操作符测试null返回object字符串。

​ 2)undefined派生自null,所以等值比较返回值是true。未初始化的变量和赋值为null的变量相等。

console.log(undefined == null);
var box = null; // 赋值为null的变量
var a; // 未初始化的变量
console.log(a == box);  // 两个的值相等   

布尔类型

​ 布尔类型有两个值:true、false。常用来做判断和循环的条件

数值型

​ 数值型包含两种数值:整型和浮点型。

​ 1)所有数字(整型和浮点型)都是以 64 位浮点数形式储存。所以,JS中1 与 1.0 相等,而且 1 加上 1.0 得到的还是一个整数。浮点数最高精度是17位小数,由于浮点数运算时可能不精确,尽量不要使用浮点数做判断。

​ 2)在存储数值型数据时自动将可以转换为整型的浮点数值转为整型。

console.log(1 == 1.0); // true
console.log(1 + 1.0); // 2
var num = 8.0; // 自动将可以转换为整型的浮点数转为整型
console.log(num); // 8

字符串

​ 使用 ' ' 或 " "引起来,如:'hello',"good"。

​ 使用加号 '+' 进行字符串的拼接,如:console.log('hello' + ' everybody');

对象

​ 对象是一组数据和功能的集合。

​ 说明:

​ {}:表示使用对象字面量方式定义的对象。空的大括号表示定义包含默认属性和方法的对象。
时间过得真快,今天的学习时间已经接近了尾声,今晚好好睡觉休息,准备好明天的学习吧!

上一篇下一篇

猜你喜欢

热点阅读