JavaScript入门①-基础知识筑基
01、JavaScript基础知识
JavaScript(缩写:JS)是一种具有面向对象能力的、解释型的程序语言,基于对象和事件驱动,具有相对安全性的客户端脚本语言。JavaScript是一门完备的 动态编程语言,当应用于 HTML 文档时,可为网站提供动态交互特性,是前端开发最主要、正式的编程语言。
ECMAScript 是由 ECMA 国际标准化组织 制定的一套脚本语言的标准化规范,JavaScript算是他的实现,作为基础语法规范,构成了JavaScript的核心。再加收浏览器提供的DOM(HTML网页内容)操作API、浏览器BOM操作API,共同组成了 JavaScript。
1.1、语法规范
JS代码以行为单位,(半角)分号;
结尾。
注释://
- 单行注释:
//
开头。 - 多行注释:
/*
多行注释*/
(同css)
代码风格:
- 区分大小写,字母、数字、下划线组成,不能数字开头,不能是关键字。
- 小驼峰命名(推荐):
initialColor
关键字: 内置的关键词:如var、do、else、enum、eval、false、for、if、void、function、switch...
语句块:花括号 { 代码块 }
1.2、引用方式
- 行内JS:元素标签内部的JS代码。
- 内部JS:定义在
<script>
标签里的JS代码,可以放到head中、body中、body后,推荐body后,先加载html再执行JS。 - 外部JS(推荐):单独的JS文件,通过script标签引入,
src
属性指定JS文件地址,此时标签中写的代码就无效了。 - 动态加载:通过DOM的API动态加载JS脚本资源,用JS创建
<script>
标签并引入资源。
<script> 属性 |
描述 | 值/备注 |
---|---|---|
src | 外部资源地址,与嵌入脚本代码不可同时使用 | <script src="js1.js" async></script> |
type | 定义脚本语言类型,可空,默认为JavaScript类型 | 支持的MIME类型包括text/javascript、 text/ecmascript、 application/javascript 和application/ecmascript |
async | 异步并行加载,只针对外部JS资源 | 多个async 脚本加载完成的顺序不确定 |
defer | 等HTML解析完成再执行JS,在DOMContentLoaded之前执行,只针对外部JS资源 | 多个脚本资源顺序加载 |
脚本加载策略:
- 如果脚本无需等待页面解析,且无依赖独立运行,那么应使用
async
。 - 如果脚本需要等待页面解析,且依赖于其它脚本,应使用
defer
,将关联的脚本按所需顺序置于 HTML 中。
<body>
<div>
<h1>基础语法</h1>
<input type="button" value="行内JS" onclick="alert('Hello world!');"/>
<input type="button" value="外部JS调用" onclick="hello();"/>
</div><hr/>
</body>
<script>
console.log("内部js:网页加载完成!");
</script>
<!-- 引入外部js文件,设置了src属性,script内部的代码就无效了 -->
<script src="../tstudy/js/js1.js" type="text/javascript" async></script>
02、变量申明var/let/const
变量,就是一个用于存放数值的容器,比如年龄=20
,“年龄”就是变量,“20”是他的树值。JS是一种弱类型语言,不需要指明数据类型,用var
或 let
关键字申明即可。
申明方式:
- 申明并赋值,1步完成:
var str="hello world";
- 先申明,再赋值,2步完成。
var str1; str1="hello world";
// 默认值为undefined
动态数据类型:JavaScript 是一种“动态类型语言”,意味着一个变量可以被赋值为各种类型数据值,通过typeof
判断数据类型。
let age;
console.log(age); //undefined
age =20;
console.log(typeof age); //number
age='年芳二十';
console.log(typeof age); //string
var | let (IE11 ES6) | const (IE11 ES6) | |
---|---|---|---|
说明 | 变量申明 | 变量申明 | 只读常量申明:申明时必须初始化值,不可更改 |
作用域 | 全局(整个文档)或整个函数体内 | 块级作用域{} 包含的区域 |
块级作用域{} |
命名规范 | 推荐:小驼峰命名 | 同var | 推荐:全大写+下划线,const MAX_SPEED |
默认值 | undefined |
undefined |
必须赋值 |
变量提升 | 提升所有var申明的变量,可以先使用后申明(不推荐),把var变量申明提升到代码头部,️注意不包括赋值 | 不会提升,顺序执行:必须先申明,后使用。存在暂时性死区 let foo=(foo+55) 第二个foo未申明报错 |
不会提升,顺序执行:必须先申明,后使用。 |
全局属性 | 在全局环境时,会成为顶级对象的属性(不可配置属性),作为全局变量存在。var age=3; //this.age;window.age |
无 | 无 |
重复申明 | 可以重复申明,覆盖前面的,有点太随意了 | 不可重复申明,作用域内重复申明会报错 ● 包括var、const申明的变量 ● 子块可重新申明let,不同的作用域了 ● 子块中用var变量会重复,var会提升 |
不可重复申明,会提示错误,同let |
申明多个 | 支持:var s1=1,st=2; |
支持:let s1,s2=2; |
支持:const s1=1,s2=2; |
性能 | 一般 | 一般 | 编译器会做常量替换优化,提升代码效率 |
总结 | 有点粗犷,不推荐 | 更严谨,推荐使用 | 不仅更严谨,性能还好,优先推荐!!! |
暂时性死区:由于没有了变量提升,及块级作用域,let、const变量只能在申明后才能用,在这之前不可用,称为“暂时性死区”。
2.1、作用域
特别注意的是 var
作用域在整个文档或函数内,整个文档也可认为是一个特殊的顶级函数。
- 如下经典的for循环示例,
var
的变量提升导致输出结果诡异。
for (var i = 1; i <= 5; i++) {
setTimeout(function () { //setTimeout为异步执行函数
console.log(i); //输出6 6 6 6 6
}, 0);
}
//换成let,则输出:1 2 3 4 5
//换成const,输出1,然后报错 Assignment to constant variable
- var作用域在整个函数
function foo() {
var x = 1; //x作用域在foo函数体内,包括嵌套函数bar也可以访问
function bar() {
var y = 2; //y作用域只在函数体bar
console.log(x); // 1
console.log(y); // 2
}
bar();
console.log(x); // 1 (`x` 在作用域内)
console.log(y); // Uncaught ReferenceError: y is not defined
}
foo();
console.log(x); // Uncaught ReferenceError: x is not defined
console.log(y); // Uncaught ReferenceError: y is not defined
- let作用域仅限
{}
块,可以是函数的块function{}
、循环的块for{}
,或者就一个孤独的块{}
。
let s1;
let s1; //Uncaught SyntaxError: Identifier 's1' has already been declared
let x = 1; //后面块内的 var x会被变量提升,导致重复变量定义报错
{
var x = 2; //Uncaught SyntaxError: Identifier 'x' has already been declared
}
2.2、变量提升
变量提升:JS引擎是先解析代码,获取所有被var
申明的变量,然后再逐行执行。只提升用var
显示申明的变量,会把所有var的申明提升到全局代码的顶部先执行,️注意只提升申明,不包括赋值。
console.log(sname); //undefined 只提升了x的变量申明,值为默认值
var sname = "sam";
var x=1;
function print() {
console.log(sname); // sam
console.log(window.sname); //sam 全局文档中申明的var变量,会作为 window 的全局变量属性
console.log(this.sname); //sam 这里的this 指向 全局对象window
}
print();
隐式全局变量:无申明变量(
str="hello";
),自动提升为隐式全局变量(不论在什么地方),类似var变量,除了没有变量提升。so,尽量不要这么使用,在严格模式下('use strict';
)这样写是会报错的。
x = 0; //未申明变量,成为隐式全局变量
function f() {
y = 1; //当执行该函数时,未申明变量,成为隐式全局变量
var z = 2; //z是函数内部申明的变量,作用域只在函数体内
}
f();
console.log(x, y); // 0 1
console.log(window.x, window.y); // 0 1
console.log(z); //Uncaught ReferenceError: z is not defined
2.3、解构赋值
解构赋值是ES6新增的语法,可以一次性给多个变量赋值,提高了编程效率,赋值操作更简洁。具体方式就是:将属性/值从对象/数组中取出,赋值给其他变量的一种赋值方式。有两种解构赋值的语法形式:
- 数组解构:类似数组的写法,从数组中按顺序赋值,这里数组可以是其他可迭代数据。
- 对象解构:类似对象的写法,从对象中按属性名赋值。
//变量一个个赋值
let x1 = 1, x2 = 2, x3 = 3, x4 = 4;
// 用数组解构赋值
let [y1, y2, y3, y4] = [1, 2, 3, 4];
[x1, x2] = [x2, x1]; //用来交换x1、x2的值,不用第三方变量
// 从对象解构赋值
let { c, d } = { a: 0, c: 1, d: 2 };
03、基础数据类型
ECMAScript 有 6 种基本类型,Undefined
、Null
、Boolean
、Number
、String
、Symbol
(符号),其他就是都是Object对象类型了,如Array
、object
、Map
、Date
、function
等。
数据类型 | 描述 | |
---|---|---|
Number | 数值:整数、小数(浮点型) ● 都是64位浮点类型存储的,最高精度17位,所以1和1.0是相等的。 ● 浮点数计算时(小数位)可能不准确,不建议用浮点数做判断。 ● 存储时会自动转换整数的浮点数值,如1.0转换为1。 |
let myAge = 17; |
Boolean | 布尔类型:有两个值true 、false |
let isFirstBlood=true; |
null | 空值关键字,表示空缺、空值,其类型为object,表示一个空对象的指针。undefined 继承自null ,等值比较时返回true。 |
注意判断object类型时须排除null。 |
Undefined | 未定义:只有一个值undefined ,表示未定义或不存在● 未赋值的变量默认为 undefined 。● 调用函数时未传递必须参数,则为 undefined 。● 函数没有返回值,默认返回 undefined 。 |
|
String | 字符串:单引号、双引号括起来,用加号+ 连接字符串。● 不可变:JS的字符串一旦创建不可变,所有更改都会创建新的字符串 ● 每一个字符元素是16 位的无符号整数值 |
|
Symbol ES6 | 符号类型,具有唯一性和不变性,常用于对象属性名 | const fooSym = Symbol('foo') |
bigint | 新添加的数据类型(ES2020) | |
object对象 | 对象:引用类型,各种值的组合 | |
Array | 数组对象 | var list1=[1,2,3]; |
JSON对象 | 对象:var jobj={name:"zhang",age:1}; |
|
function | 函数,本身也是对象 | function f1(){/*...*/} |
️注意不要将基本类型中的布尔值 true / false 与值为 true/false 的 Boolean 对象弄混了,基本类型Boolean是一个对象。
console.log(typeof 1); //number
console.log(typeof true); //boolean
console.log(typeof null); //object
console.log(typeof undefined); //undefined
console.log(typeof 'abc'); //string
console.log(null == undefined); //true 值比较
console.log(null === undefined); //false 恒等比较
//boolean
const x = new Boolean(false); //new Boolean()创建了基本类型Boolean的对象,就不是一个平平无奇的值类型了。
console.log(typeof x); //object
console.log(x.valueOf()); //false valueOf()方法获取对象的基本数据的值
console.log(Boolean(undefined)); //false
console.log(Boolean(null)); //false
console.log(Boolean(NaN)); //false
console.log(Boolean(0)); //false
console.log(Boolean("")); //false
console.log(Boolean(1)); //true
console.log(Boolean(-100)); //true
console.log(Boolean("abc")); //true
3.1、Number数字
Number的属性、方法:
属性/方法 | 描述 | 示例 |
---|---|---|
静态属性/方法 | ||
Number.NaN | NaN是一个特殊的Number值,即非数值(Not a Number) ● NaN和任何值都不相等,包括它自己,和任何值计算都为NaN ● Math 、parseInt 函数执行失败会返回NaN |
同window.NaN |
Number.MAX_VALUE | 最大数值(静态属性),值接近于 1.79E+308 | |
Number.MIN_VALUE | 最接近 0 的正值,而不是最小的负值,约为 5E-324 | |
Number.isNaN() IE | 判断是否等于NaN,window.isNaN 是判断是否非数值,坑! |
只有NaN才返回true |
Number.isInteger() IE | 是否为整数 | |
Number.parseFloat() IE | 解析浮点数,从第一个非空字符解析获取数字,识别第一个小数点 | 同window.parseFloat() |
Number.parseInt() IE | 解析整数,从第一个非空字符解析获取数字,支持进制参数 | 同window.parseInt() |
构造函数 | ||
Number() | 转换为数字(忽略空格)。Number()转换数据不同于parseint、parseFloat,要求必须为合法数字,要求更严格,不成功便成仁。 | Number(true) //1 |
实例属性/方法 | ||
toFixed(小数位数) | 转换为指定小数位数的字符,多了会四舍五入,不足用0补位 | n1.toFixed(2) |
toString() | 转字符串,参数可以指定基数(进制) | n2.toString(2) //2进制 |
注意浮点数的精度:
0.1+0.2 //输出 0.3000000000000000**4**
。由于浮点数的精度问题,永远不要用浮点数值去做条件判断。这种错误是由于IEEE 754标准导致的。
Number.parseFloat("123.4a5"); //123.4
Number.parseInt("123.4a5"); //123
//注意,两个方法是不同的,全局的window.isNaN()是判断是否非数值。
window.isNaN("a") //true
Number.isNaN("a") //false //这属于JS坑爹的设计,两个含义完全不同
console.log(Number("")); //0
console.log(Number("123abc")); //NaN,不同于parseint、parseFloat
console.log(Number("12.12.12")); //NaN,不同于parseint、parseFloat
console.log(Number.parseFloat("12.12.12")); //12.12
let n1=1.336,n2=100;
n1.toFixed(2) //1.34
n2.toFixed(2) //100.00
window.parseFloat(string):从字符串的第一位(空字符会被忽略)开始,如果是数字(正号+
、负号-
、数字0-9
、第一个小数点.
、科学计数法e/E
)则转数字,直到非数字或结束。
console.log(parseFloat("123abc")); //123
console.log(parseFloat("abc123")); //NaN
console.log(parseFloat("11.11")); //11.11
console.log(parseFloat("11.11.33")); //11.11
window.parseint(string):同parseFloat,除了不识别小数点。
console.log(parseInt("123abc")); //123
console.log(parseInt("abc123")); //NaN
console.log(parseInt("11.11")); //11
3.2、String字符串
String:字符串对象,提供各种字符串操作。
属性/方法 | 描述 | 示例 |
---|---|---|
构造函数 | ||
String() | 支持任意值转换为字符串,包括null 、undefined ,都是直接加引号,很粗暴!可以用来判断null、undefined |
String(null) //"null" |
实例属性/方法 | ||
length | 字符串长度 | "abc".length; // 3 |
charAt(index) | 返回指定位置的字符 | |
indexOf(char) | 返回字符的索引位置,从前往后找,lastIndexOf 是从后往前找 |
s1.indexOf("12") |
substr(start,length?) | 截取字符串:指定起始位置、长度,无length 到结尾(下同) |
s1.substr(2) |
substring(start,end?) | 截取字符串:指定起始位置、结束位置 | |
slice(start,end?) | 截取字符串:起始位置、结束位置,同substring ,区别是支持负数(倒数),(slice /slaɪs/ 切片) |
str.slice(0,-1);//截取0到倒数第二位置的字符 |
split(separator,limit?) | 按照分隔符分割字符串为数组 | (split /splɪt/ 分裂) |
trim() | 移除首尾的空白字符,返回新字符,不会改变原有字符。 | |
trimStart() | 同上,值移除开头的空白字符,还有移除末尾的trimEnd () |
|
padStart(len,str) | 从头补齐字符长度到len ,str为去替补的字符,没有则空格 |
"12".padStart(5,'0') |
padEnd(len,str) | 补齐字符长度,从尾部开始 | |
replace(old, new) | 字符替换,str.replace("台湾","台湾省") ,支持正则和函数 |
|
repeat(n) | 创建一个重复n次的新字符串 | "12".repeat(2) //1212 |
toLowerCase() | 字符转小写,大写是toUpperCase() |
|
includes(str) | 判断是否包含指定的字符串 | |
startsWith(str) | 判断是否以指定字符开头,endsWith()判断结尾 | |
search(str) | 字符搜索或正则匹配搜索 | |
match(regexp) | 正则匹配搜索字符 |
字符串的不变性:字符串一经创建不会改变。 let str="abc"; str="123";
- 这里的不改变,不是字符变量
str
不能修改,是指字符串"abc"
本身不可更改,修改str
会创建新的字符。所以,字符的操作都不会影响原来的字符串值,而是创建新的字符串。 - 字符连接创建新字符:字符的连接,如
+
,会创建新的字符串。
模板字符串(IE):${var}
+反引号 `` 包装
板字符串可以包含特定语法(${expression}
)的占位符,由一个内置函数负责计算表达式并输出最终的字符串。
let x=1,y=2;
console.log(`sum: ${x} + ${y} = ${x+y}`); //sum: 1 + 2 = 3
JavaScript 特殊/转义字符:在字符串中使用的特殊符号
字符 | 描述 |
---|---|
\0 | Null 字节 |
\b | 退格符 |
\f | 换页符 |
\n | 换行符 |
\r | 回车符 |
\t | Tab (制表符) |
\v | 垂直制表符 |
\' | 单引号 |
\" | 双引号 |
\\ | 反斜杠字符(\) |
3.3、类型( 隐式 )转换
隐式类型转转换,是自动进行的,也叫自动类型转换。
值 | 字符串 | 数字 | 布尔值 |
---|---|---|---|
undefined | "undefined" | NaN | false |
null | "null" | 0 | false |
true | "true" | 1 | true |
false | "false" | 0 | false |
""(空字符) | "" | 0 | false |
"1.5" | "1.5" | 1.5 | true |
"one" | "one" | NaN | true |
0 | "0" | 0 | false |
-1 | "-1" | -1 | true(非0数字都true) |
1 | "1" | 1 | true |
NaN | "NaN" | NaN | false |
[](空数组) | 0 | true | |
[5]一个数字 | 里面的数字5 | true | |
["a"][1,2]其他数组 | NaN | true | |
{...}对象 | NaN | true |
隐式转换总结:
- 转boolean:undefined、null、NaN、0、空字符转bool都为false;非0数字(包括负数)、非空字符(包括”true“、”false“)、对象、空数组[] 转
boolean
都为true。 - 转数字:非空字符串都是数字(忽略空格)的转对应数字,否则NaN;null、空字符转数字为0。
- 转字符串:任意类型转字符串加引号,包括undefined、null。
- +运算:字符串+任意类型(包括空字符)均转换为字符串;boolean、数字转数值进行相加。
-
、*
、/
、%
运算:都是隐式转换为数值运算。==、>、<
比较运算符:不同的值类型转数字;都是字符比较码值;如果存在对象,先转换为原始值。
console.log("-1" - 1); // -2
console.log(2 > true); // true
console.log("one" + true); // onetrue
console.log("1.5" * 2); // 3
console.log("1.5" + 2); // 1.52
console.log([5] / 2); // 2.5
显示类型转换就是调用各种方法、类型构造函数进行显示的数据转换。
- toString():基本每种数据类型都提供了toString()方法,转换为字符串,除开null和undefined不可使用,会报错。
- 类型构造函数:Boolean()、Number()、String()的类型函数,都可以转换对应数据类型。
- valueOf():valueOf()方法可以转换对象为一个基本数据值。
- 其他如parseInt()、parseFloat()...等方法。
3.4、值类型与引用类型
️堆和栈:
- 栈(stack):提供代码执行环境,并存放值类型、变量标识符。速度快,空间有限(不同浏览器不同)。
- 堆(heap):存放引用类型数据,速度慢,空间大。
值类型(基本类型) | 对象/引用类型 | |
---|---|---|
数据类型 | undefined、null、Boolean、Number、String、Symbol | Array、object、window,function等 包装类型:String、Number、Boolean; 单体内置对象:Global、Math |
存储位置 | 存储在栈中(变量标识符、变量值),占用空间固定 |
存储在堆中,占用空间不固定。变量标识符存储在栈区,值为地址指针,指向存储在堆区的对象数据。 |
属性方法 | 不能添加任何属性、方法。 | 可以动态添加属性和方法 |
复制 | 复制变量值 | 复制地址指针(变量值是对象的指针),指向同一对象 |
参数传递 | 值传递,不影响原有变量 | 引用地址传递,共用同一个对象 |
垃圾回收 | 函数执行完就回收了 | 没有任何引用时,才会被垃圾回收机制收回 |
类型验证 | typeof :typeof 0; //number |
instanceof :[] instanceof Array //true Object.prototype.toString.call({}) //[object Object] |
==比较 | 值类型是值比较 | 引用类型比较引用地址,所以要用恒等=== 比较 |
04、运算/操作符
4.1、算数运算符
运算符 | 描述 | 示例 |
---|---|---|
+ | 加 | |
- | 减 | |
* |
乘 | |
/ | 除 | |
% | 取余数 | 6%3; //=0 |
** |
指数,幂运算,等同于Math.pow(a,b) | 3**2; //=Math.pow(3,2)=9 |
++ | 自加1,符号在前面的先运算,再赋值,在后面的反之 | x=++y; //y=1+y; x=y; x=y++; //x=y;y=1+y; |
-- | 自减1,同上 |
运算符优先级:
[ ++,--,!] > [*,/,% ] > [ +,- ]
var x=1; //经典面试题
console.log(x+x++ + ++x); //1+1+(1+2)=5
+
加运算符会隐式转换:+运算就是字符相加、数字相加两种情况
- boolean、数字相加会隐式转换为数值进行相加。
- 字符串 + 非字符串会隐式转换为字符串。
console.log(true+false); //1
console.log(true+3); //4
console.log(true+"1"); //true1
console.log("123"+123); //123123
console.log("123"+[1,2,3]); //1231,2,3
-
,*
,/
,%
隐式转换数值:都是数学运算转数字。减、乘、除、取余运算都是数学运算,会隐式转换为数字再运算。
console.log("123"-"12"); //111
console.log("123"-12); //111
console.log("123"-1-true); //121
console.log("123"/true); //123
console.log("123"/2); //61.5
4.2、⏸️赋值运算符
运算符 | 描述 | 示例 |
---|---|---|
= | 赋值运算符,一个神圣的仪式 | |
+= | 加法赋值 | x+=y //x=x+y |
-= | 减法赋值 | x-=y //x=x-y |
*= | 乘法赋值 | x*=y //x=x*y |
/= | 除法赋值 | x/=y //x=x/y |
%= | 取余赋值 | a%=3 //a=a%3 |
4.3、比较运算符
运算符 | 描述 | 示例/备注 |
---|---|---|
>,<,>=,<= | 大于,小于,大于等于,小于等于 | |
== | 相等比较,比较变量的值,而不管其类型 | "1"==1; //true |
=== | 恒等比较,比较类型和值 | 无类型转换 |
!= | != 不等于比较 |
|
!== | !== 不恒等比较 |
无类型转换 |
比较运算符会隐式转换为数值!
- 都是字符,转为码值进行比较,
- 两个不同类型比较,隐式转为数值,然后进行比较。
- 引用类型永远不相等,虽然其内部的数据一模一样,因为比较的是引用地址。
- 推荐恒等,由于
==
、!=
比较会隐式转换,会遇到较多奇葩问题,在开发中,我们一般使用严格比较恒等===
!==
。 - NaN与任何值比较,都是false, Infinity 只等于它自身。
console.log(NaN==NaN); //false
- null 和 undefined, 他们直接相等,和其他原始类型比较,不相等。
console.log("123">"45"); //false 都是字符比较字符码值
console.log("123">45); //true 转换为数值比较
console.log("123"==123); //转数值比较,true
console.log(""==false); //true 转为数值比较
console.log("false"==false); //false 转为数值比较
console.log("true"==true); //false 转为数值比较
console.log([1,2,3]==[1,2,3]); //false,数组是对象
4.4、逻辑运算符
运算符 | 描述 | 示例/备注 |
---|---|---|
! | ! 逻辑非运算符 |
!false //true |
&& | && 、|| 也叫短路运算符:从左往右判断,符合要求就不继续执行了逻辑与 && =同时满足:返回第一个为false 的值,否则最后一个值 |
1 && 2 && 3 //返回3 1 && 2 && false && 3 //返回false |
|| | 逻辑或=满足一个即可:返回第一个为true 的值,否则最后一个值 |
1 || 2 || false //返回1 |
逻辑运算符会隐式转换为
boolean
值。
短路运算符&&
、||
常用来判断都为真、至少有一个为真:
let user = { name: "sam", score: 98, age: 12 };
if (user.age <= 12 && user.score > 95)
console.log(`${user.name} 是一个少年天才!`);
4.5、️其他操作符
运算符 | 描述 | 示例 |
---|---|---|
?: | 三元表达式:判断条件 ?条件为真 :条件为假 |
age = 4 > 2 ? 4 : 2; //4 |
??= | 逻辑空赋值运算符: (x ??= y) 仅在 x 是(null 或 undefined) 时对其赋值y | x??="default"; |
?. || | 可选链运算符,不为空(null 或 undefined)时才执行。可以没有 ||,返回undefined |
page=res?.data?.size ||1;obj?.[prop]; obj.func?.() |
void | 运行表达式,返回一个 undefined | void alert("void") |
&,|,~,^,<<,>> | 二进制位的运算,32位数字的位运算 | |
delete | 删除一个对象的属性、数组键值,删除后会变为undefined | delete objt.pro |
typeof | 获取数据类型,typeof (operand) ,括号省略。 |
typeof null; //object |
in | 判断属性是否在对象中 | "length" in [] //true |
instanceof | 判断对象是否指定的类型,用于引用类型、自定义类型 | [] instanceof Array //true |
new | new Object() 创建对象实例 |
|
superIE | 调用一个对象父类的函数,在子类中调用 | supper.print(); |
05、逻辑语句
if/switch条件判断
if
条件语句,根据条件执行。if
可单独使用,也可以跟else if
(0个或多个,中间)、else
(0个或1个,放最后)。
if (条件) { /*代码*/ }
else if(条件) { /*代码*/ }
else if(条件) { /*代码*/ }
else { /*代码*/ } //可以不要else部分,单独if
switch
定值条件分支,值的判断是用的===
恒等比较,多用于枚举值、固定的常量值。注意每一个case后需要用break,以防止穿透(继续往后执行)。
switch (表达式) {
case 值1:
/*代码*/;
break; //返回,结束switch,防止无意义的穿透执行
case 值2:
case 值3: //可以多case合并一块
/*代码*/;
break;
default: //前面的case都没有命中时执行
/*代码*/
}
try.catch异常处理
用 try...catch...finally 语句捕获异常,throw语句抛出一个异常。
- JS代码如果发生了异常,则不会再执行后面的代码了,就需要做好异常捕获处理。
finally
语句块为可选,不管是否抛出异常都会执行,常用来做一些清理收尾工作。throw
抛出异常,可以是自定义的值、对象,可以用Error
对象包装一个错误信息。
function print(para) {
if (para <= 0) {
throw "参数para必须大于0(para= "+para+")";
throw new Error("参数para必须大于0(para= "+para+")");
}
console.log(para);
}
print(2); //如果这里参数用-2,则会抛出异常,这里的异常没人管,后面的代码就不会执行了
try{ //try包装要执行的代码
print(-2);
}
catch(e){ //catch捕获try中抛出的异常并处理,参数为捕获到的异常信息,如果没有异常则跳过catch语句
console.log("发生错误:" + e);
}
finally{
console.log("执行完毕!") //始终会被执行的代码,用于一些清理收尾工作
}
break/continue
- break:结束循环,停止本层循环,跳出本层循环,大家都别干了!
- continue:结束本次循环,暂停本次循环,不执行后面的代码了,继续下一次循环,我不想干了,你们继续!
while(true) { }
while
循环,先判断,符合条件才执行,会循环的判断条件 》执行,所以必须注意结束循环的控制,不然就是死循环了。
while(条件表达式){
/*循环代码*/
//条件控制代码,别忘了
}
do{ } while (true)
do...white
循环,先执行 》再判断。同while,需注意循环的控制,避免死循环。
do{
/*循环代码*/
//条件控制代码,别忘了
}while(条件表达式)
for(i,i<n,i++){ }循环
循环执行逻辑控制语句:
for(初始化语句;判断条件语句;控制条件语句){
/*循环代码*/
}
for(let i=1;i<=10;i++){ //循环1到10
if(i>6)
break; //跳出并结束循环
if(i%2==1)
continue; //如果是奇数,返回继续下一次循环
console.log(i);
}
for(in){ }可枚举属性
for...in循环,对一个对象(不仅仅是数组)进行循环遍历,遍历其所有可枚举的属性(索引下标、属性),包括继承来的。
let arr=[1,2];
arr.uname="arr";
arr.print=function(){console.log(this.length)};
for(let i in arr){
console.log(i+":"+arr[i]);
}
/*输出:
0:1
1:2
uname:arr
print:function(){console.log(this.length)}
*/
慎用
for(in)
:for(in)是循环遍历的是所有可枚举的(enumerable)属性,对于数组、可迭代集合一般使用for(of)
。
for(of) {}集合值迭代
for…of(IE)语法是ES6新引入的语法,用于遍历可迭代(iterable)对象,只遍历数组对象元素。包括字符串String、数组Array、集合Set、字典Map、arguments 对象、DOM NodeList 对象等。
和for...in
最大的区别就是,for...of
迭代的是集合的数据值,而不是可枚举属性(索引)。
let arr=[1,2];
arr.uname="arr";
arr.print=function(){console.log(this.length)};
for(let i of arr){
console.log(i); //1 2
}
forEach()数组方法
forEach 作用于数组对象,用于遍历数组对象的每一个元素,并对每一个元素执行回调(callback)函数。
语法:ArrayObject.forEach(callback(currentValue, index, arr), thisValue))
let arr = [1, 2];
arr.uname = "arr";
arr.print = function () { console.log(this.length) };
arr.forEach(function (item, index) {
console.log(index + ":" + item);
});
/*输出:
0:1
1:2
*/
️版权申明:版权所有@安木夕,本文内容仅供学习,欢迎指正、交流,转载请注明出处!原文编辑地址-语雀
JavaScript入门①-基础知识筑基的更多相关文章
- javascript入门基础知识
JavaScript介绍: 1. javascrip是互联网上最流行的脚本语言,可用于Web和HTML,更可广泛用于服务器.pc端.移动端. 2. javascript脚本语言: javascript ...
- React Native 入门基础知识总结
中秋在家闲得无事,想着做点啥,后来想想,为啥不学学 react native.在学习 React Native 时, 需要对前端(HTML,CSS,JavaScript)知识有所了解.对于JS,可以看 ...
- JavaScript入门基础
JavaScript基本语法 1.运算符 运算符就是完成操作的一系列符号,它有七类: 赋值运算符(=,+=,-=,*=,/=,%=,<<=,>>=,|=,&=).算术运 ...
- USB入门基础知识(转)
源:USB入门基础知识 相关名词: 主机(Host) 设备(Device) 接口(Interface) 管道(Pipe) 管道是主机与设备端点数据传输的连接通道,代表了主机的数据缓冲区与设备端点之间交 ...
- Linux入门基础知识
注:内容系兄弟连Linux教程(百度传课:史上最牛的Linux视频教程)的学习笔记. Linux入门基础知识 1. Unix和Linux发展历史 二者就像父子关系,当然Unix是老爹.1965年,MI ...
- 快速掌握JavaScript面试基础知识(三)
译者按: 总结了大量JavaScript基本知识点,很有用! 原文: The Definitive JavaScript Handbook for your next developer interv ...
- 快速掌握JavaScript面试基础知识(二)
译者按: 总结了大量JavaScript基本知识点,很有用! 原文: The Definitive JavaScript Handbook for your next developer interv ...
- Greenplum入门——基础知识、安装、常用函数
Greenplum入门——基础知识.安装.常用函数 2017年10月08日 22:03:09 在咖啡里溺水的鱼 阅读数:8709 版权声明:本文为博主原创,允许非商业性质转载但请注明原作者和出处 ...
- 1)Linux程序设计入门--基础知识
)Linux程序设计入门--基础知识 Linux下C语言编程基础知识 前言: 这篇文章介绍在LINUX下进行C语言编程所需要的基础知识.在这篇文章当中,我们将 会学到以下内容: 源程序编译 Makef ...
- javascript的基础知识及面向对象和原型属性
自己总结一下javascript的基础知识,希望对大家有用,也希望大家来拍砖,毕竟是个人的理解啊 1.1 类型检查:typeof(验证数据类型是:string) var num = 123; cons ...
随机推荐
- Nginx 动态压缩与静态压缩,显著提高前后端分离项目响应速度!
文章转载自:https://mp.weixin.qq.com/s/NuTmEUQU5L69is53bCauKA Nginx 中配置前端的 gzip 压缩,有两种思路: Nginx 动态压缩,静态文件还 ...
- Docker 部署 RocketMQ Dledger 集群模式( 版本v4.7.0)
文章转载自:http://www.mydlq.club/article/97/ 系统环境: 系统版本:CentOS 7.8 RocketMQ 版本:4.7.0 Docker 版本:19.03.13 一 ...
- kubeadm使用外部etcd部署kubernetes v1.17.3 高可用集群
文章转载自:https://mp.weixin.qq.com/s?__biz=MzI1MDgwNzQ1MQ==&mid=2247483891&idx=1&sn=17dcd7cd ...
- 第四章:Django表单 - 4:表单的Widgets
不要将Widget与表单的fields字段混淆.表单字段负责验证输入并直接在模板中使用.而Widget负责渲染网页上HTML表单的输入元素和提取提交的原始数据.widget是字段的一个内在属性,用于定 ...
- Jenkins配置项目构建的钉钉通知
在任意一个钉钉群里创建自定义的钉钉机器人,然后能够看到钉钉开放的webhook,复制webhook. Jenkins中安装钉钉插件,然后在项目的配置当中,构建后操作里添加钉钉报警. 安装钉钉通知插件 ...
- flutter系列之:深入理解布局的基础constraints
目录 简介 Tight和loose constraints 理解constraints的原则 总结 简介 我们在flutter中使用layout的时候需要经常对组件进行一些大小的限制,这种限制就叫做c ...
- nsis离开自定义页面保存设置
这是群里一位朋友问他的自定义页面设置完成后返回上一步无法保存怎么办写的一个小例子,拓展了下,只要不关闭,不管上一步还是进入下一步返回都可以保留原页面设置. !include LogicLib.nsh ...
- sg函数入门理解
首先理解sg函数必须先理解mex函数 mex是求除它集合内的最小大于等于0的整数,例:mex{1,2}=0:mex{2}=0:mex{0,1,2}=3:mex{0,5}=1. 而sg函数是啥呢? 对于 ...
- 洛谷P2367 语文成绩(差分)
标准的差分应用题,不要想的太复杂,写成了线段树. 1 #include<bits/stdc++.h> 2 using namespace std; 3 const int N=5e6+10 ...
- python锦鲤
今日内容目录 垃圾回收机制 流程控制理论& 流程控制之分支结构& 流程控制之循环结果& 详情 Python垃圾回收机制 """ 有一些语言,内存空 ...