이 기사는 기본 문법과 관련된 문제를 주로 소개하는 javascript에 대한 지식을 제공합니다. JavaScript는 인터넷에서 가장 인기 있는 스크립트 언어입니다. 모두에게 도움이 되기를 바랍니다.
【관련 권장 사항: javascript 비디오 튜토리얼, web front-end】
JavaScript는 인터넷에서 가장 널리 사용되는 스크립트 언어입니다. 이 언어는 HTML 및 웹에 사용할 수 있습니다. 서버, PC, 노트북, 태블릿, 스마트폰 및 기타 장치에서 널리 사용됩니다.
JavaScript 기능
JavaScript는 ECMAScript를 통해 ECMA(유럽 컴퓨터 제조 협회)에 의해 언어로 표준화되었습니다.
연도 | 이름 | 설명 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1997 | ECMAScript 1 | 첫 번째 버전 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
1998 | ECMA 스크립트 2 | 버전 변경 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
1999 | ECMAScript 3 | ㅋㅋㅋ 2011 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
버전 변경 | 2015 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
클래스 및 모듈 추가 | 2016 | ECMAScript 7|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Array.prototype이 추가되었습니다 |
UsageHTML의 스크립트는 3f1c4e4b6b16bbbd69b2ee476dc4f83a 태그 사이에 배치되어야 합니다. 스크립트는 HTML 페이지의 6c04bd5ca3fcae76e30b72ad730ca86d 섹션에 배치할 수 있습니다. 일반적으로 사용자가 버튼을 클릭하는 등 이벤트가 발생할 때 코드를 실행해야 합니다. JavaScript 코드를 함수 안에 넣으면 이벤트가 발생할 때 해당 함수를 호출할 수 있습니다. 예제 1: head의 스크립트 함수 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>head标签中script</title> <script> function myFunction() { document.getElementById("demo").innerHTML = "这是我的函数"; } </script> </head> <body> <h1>我的函数</h1> <p id="demo">一段话</p> <button type="button" onclick="myFunction()">这是函数</button> </body> </html> 예제 2: body의 스크립트 함수 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>body中的script</title> </head> <body> <h1>我的函数</h1> <p id="demo">我的函数</p> <button type="button" onclick="myFunction()">点击一下</button> <script> function myFunction() { document.getElementById("demo").innerHTML = "这是我的函数" } </script> </body> </html> JavaScript는 호출을 위해 외부에 배치할 수도 있습니다. 외부 확장자는 .js입니다. 예 3: JavaScript에 대한 외부 호출 External call.js function myFunction() { document.getElementById('demo').innerHTML = "这是我的函数" } Call external script <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>调用外部script</title> </head> <body> <p id="demo">一段文字</p> <button type="button" onclick="myFunction()">尝试一下</button> <script src="外部脚本.js"></script> </body> </html> OutputJavaScript는 다양한 방식으로 데이터를 출력할 수 있습니다.
예제 1: aler() 팝업 창 출력 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>alert输出</title> </head> <body> <h1>alert输出</h1> <script> window.alert(5 + 6) </script> </body> </html> 예제 2: document.write() 출력 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>document.write输出</title> </head> <body> <h1>document.write输出</h1> <script> document.write(Date()); document.write("Hello,Web!"); </script> </body> </html> 예제 3: HTML 문서에 쓰기 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>写到HTMl文档</title> </head> <body> <h1>写到HTMl文档</h1> <script> function myFunction() { document.write("函数输出"); } </script> <button onclick="myFunction()">点击这里</button> </body> </html> 예제 4: console.log()를 사용하여 쓰기 브라우저 서버 콘솔 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>使用console.log()写入到浏览器的控制台</title> </head> <body> <h1>console.log()写入到浏览器的控制台</h1> <script > a = 5; b = 6; c = a + b; console.log(c) </script> </body> </html> 구문 소개JavaScript는 스크립팅 언어로, 가볍지만 강력한 프로그래밍 언어입니다. Literals 프로그래밍 언어에서는 일반적으로 고정된 값을 리터럴이라고 합니다.
JavaScript에서는 명령문이 ";"으로 끝나야 합니다. JavaScript 변수 프로그래밍 언어에서 변수는 변수를 정의하고 등호를 사용하여 값을 할당하는 데 사용됩니다. 변수는 서로 작용할 수 있습니다. var y = false // 布尔值 var length = 16; // 数字 var points = x * 10; // 数字计算 var lastName = "Johnson"; // 字符串 var cars = ["Saab", "Volvo", "BMW"]; // 数组 var person = {firstName:"John", lastName:"Doe"}; // 对象字典 JavaScript 함수 동일한 함수를 반복적으로 참조하고 코드 작성 및 유지 관리의 편의성을 줄이기 위해 JavaScript에서는 키워드 함수에서 제공하는 함수 함수를 제공합니다. 가이드: function myFunc(a, b) { return a + b; // 返回a+b结果 } JavaScript 기능 다른 언어와 비교하여 JavaScript에는 다음과 같은 특징이 있습니다.
大部分语言能够自动补全空格,我们建议在运算符两边加上空格,这样清晰美观,但是要注意在HTML中空格的是要留意用法的,切勿混谈。在JavaScript中,下面两句话是一样的: var a = 10; var b=10; 与Python相似,JavaScript也是脚本语言,属于解释型。 对象定义对象 任何事物都是对象,具有相同特点的事物中抽象出来的一个特点实例。如人类中的小明。 在JavaScript中,对象就是是属性变量的容器,类似Python中的字典,Java中的哈希映射,其中定义了对象的属性。 var people = { firstName: "Mike", lastName: "Smith", age: "18", address: "Beijing", job: "Student" }; 以上就是对象定义,当然你也可以写作一行,我这样是为了美观,以后也强烈大家这样写。 访问对象属性 可以说 "JavaScript 对象是变量的容器"。但是,我们通常认为 "JavaScript 对象是键值对的容器"。键值对通常写法为key : value(键与值以冒号分割),键值对在JavaScript对象通常称为对象属性。我们访问属性也是通过万能的" . "(大部分语言都是用的这个)。 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>这是网站</title> </head> <body> <h1>访问类属性</h1> <!--下面语句一定要在script之前--> <p id="demo"></p> <script> var people = { firstName: "Mike", lastName: "Smith", age: "18", address: "Beijing", job: "Student" }; document.getElementById("demo").innerHTML = people["firstName"] + "." + people.lastName; </script> </body> </html> 两种访问方式,你可以使用 对象名 .property 或 对象名.["property"] 。 函数函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块。当调用该函数时,会执行函数内的代码。可以在某事件发生时直接调用函数(比如当用户点击按钮时),并且可由 JavaScript 在任何位置进行调用。 参数与返回值 在调用函数时,您可以向其传递值,这些值被称为参数,参数个数不限。
参数在调用时,应该严格按照其顺序传参,如下所示: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>这是一个JavaScript网站</title> </head> <body> <h1>函数参数传递问题</h1> <p>点击下面按钮调用</p> <button onclick="myFunc('Mike','18','Beijing')">点击这里</button> <script> function myFunc(name, age, address) { alert("My name is " + name + ", age is " + age + " and my home is in " + address); } </script> </body> </html> JavaScript函数允许有返回值,返回关键字为return。当函数返回值后,函数将停止执行,在return后面的语句将不会被执行。 实例:计算两个数的乘积并返回结果 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>JavaScript网站</title> </head> <body> <h1>计算两个数的值返回</h1> <p id="demo"></p> <script> function myFunc(a, b) { return a * b; } document.getElementById("demo").innerHTML = myFunc(3, 4); </script> </body> </html> 变量 JavaScript变量分为两种:
当我们向未声明的JavaScript变量分配值时,该变量将被自动作为window的一个属性。如下列语句: name = "Mike"; 将声明window的一个属性name。非严格模式下给未声明变量赋值创建的全局变量,是全局对象的可配置属性,可以删除。如: var var1 = 1; // 不可配置全局属性 var2 = 2; // 没有使用 var 声明,可配置全局属性 console.log(this.var1); // 1 console.log(window.var1); // 1 delete var1; // false 无法删除 console.log(var1); //1 delete var2; console.log(delete var2); // true console.log(var2); // 已经删除 报错变量未定义 事件描述 HTML事件是发生在HTML元素上的事情。当在 HTML 页面中使用JavaScript时, JavaScript可以触发这些事件。 HTML事件可以是浏览器行为,也可以是用户行为。以下是HTM 事件的实例:
通常,当事件发生时,你可以做些事情。在事件触发时JavaScript可以执行一些代码。HTML元素中可以添加事件属性,使用JavaScript代码来添加HTML元素。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>JavaScript事件</title> </head> <body> <h1>JavaScript事件处理两种方式</h1> <p id="demoOne"></p> <button onclick="getElementById('demoOne').innerHTML=Date()">点击查看时间1</button> <p id="demoTwo"></p> <button onclick="this.innerHTML=Date()">点击查看时间2</button> </body> </html> JavaScript通常是多行代码,比较差常见的就是通过事件属性调用。 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>JavaScript事件</title> </head> <body> <h1>JavaScript事件之属性调用</h1> <p>点击执行<em>myFunc()</em>函数</p> <button onclick="myFunc()">点击这里</button> <p id="one"></p> <script> function myFunc() { document.getElementById("one").innerHTML = Date(); } </script> </body> </html>
后续会继续学习更多事件。 事件作用 事件可以用于处理表单验证,用户输入,用户行为及浏览器动作:
可以使用多种方法来执行 JavaScript 事件代码:
字符串字符串:一系列字符的集合。 var a = "abc"; var b = "Hello"; 与Python类似,可以使用索引来访问字符串中的每个字符: var c = b[1]; // e length 该属性可以计算字符串的长度。 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>字符串长度</title> </head> <body> <script> var txtOne = "Hello World!"; document.write("<p>" + txtOne.length + "</p>"); var txtTwo = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; document.write("<p>" + txtTwo.length + "</p>"); </script> </body> </html> JavaScript也有一些特殊字符,例如当我们要打印引号时,需要加上“\”来进行转义,否则编译器无法解析。
字符串作为对象 通常,JavaScript字符串是原始值,可以使用字符创建: var firstName = "Mike",但我们也可以使用new关键字将字符串定义为一个对象:var firstName = new String("Mike"),这点与Java类似。
==与===区别 1、对于 string、number 等基础类型,== 和 === 是有区别的
2、对于 Array,Object 等高级类型,== 和 === 是没有区别的 进行 "指针地址" 比较 3、基础类型与高级类型,== 和 === 是有区别的
4、!= 为 == 的非运算,!== 为 === 的非运算 var num=1; var str="1"; var test=1; test == num //true 相同类型 相同值 test === num //true 相同类型 相同值 test !== num //false test与num类型相同,其值也相同, 非运算肯定是false num == str //true 把str转换为数字,检查其是否相等。 num != str //false == 的 非运算 num === str //false 类型不同,直接返回false num !== str //true num 与 str类型不同 意味着其两者不等 非运算自然是true啦 运算符
JavaScript 还包含了基于某些条件对变量进行赋值的条件运算符。如: variablename=(condition)?value1:value2 条件判断在 JavaScript 中,我们可使用以下条件语句:
if语句 条件为true时才会执行代码。如: <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>JavaScript网站</title> </head> <body> <h1>这是if语句</h1> <button onclick="myFunc()">点击这里</button> <p id="one"></p> <script> function myFunc() { var x = ""; var time = new Date().getHours(); if (time < 20) { x = "Hello, Before 20:00"; } document.getElementById("one").innerHTML = x; } </script> </body> </html> if...else语句 使用 if....else语句在条件为true时执行代码,在条件为false时执行其他代码。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>JavaScript网站</title> </head> <body> <h1>这是if...else语句</h1> <button onclick="myFunc()">点击这里</button> <p id="one"></p> <script> function myFunc() { var x = ""; var time = new Date().getHours(); if (time < 20) { x = "Hello, Before 20:00"; }else { x = "Hello, After 20:00"; } document.getElementById("one").innerHTML = x; } </script> </body> </html> 多重if..else语句 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>JavaScript网站</title> </head> <body> <h1>多重if...else语句</h1> <button onclick="myFunc()">点击这里</button> <p id="one"></p> <script> function myFunc() { var x = ""; var time = new Date().getHours(); if (time < 12) { x = "上午好"; } else if (time < 14) { x = "中午好"; } else { x = "下午好"; } document.getElementById("one").innerHTML = x; } </script> </body> </html> switch语句 使用switch语句来选择要执行的多个代码块之一。如: <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>JavaScript网站</title> </head> <body> <h1>switch语句</h1> <button onclick="myFunc()">点击这里</button> <p id="one"></p> <script> function myFunc() { var x = ""; var time = new Date().getMonth(); switch (time) { case 0: x = "January"; break; case 1: x = "February"; break; case 2: x = "March"; break; case 3: x = "April"; break; case 4: x = "May"; break; case 5: x = "Jane"; break; case 6: x = "July"; break; case 7: x = "August"; break; case 8: x = "September"; break; case 9: x = "October"; break; case 10: x = "November"; break; case 11: x = "December"; break; default: x = "ERROR"; } document.getElementById("one").innerHTML = x; } </script> </body> </html> 循环JavaScript 支持不同类型的循环:
for循环 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>JavaScript循环</title> </head> <body> <h1>点击按钮循环代码5次。</h1> <button onclick="myFunc()">点击这里</button> <p id="demo"></p> <script> function myFunc() { var x = ""; for (var i = 0; i < 5; i++) { x = x + "该数字为 " + i + "<br>"; } document.getElementById("demo").innerHTML = x; } </script> </body> </html> fo /in循环 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>点击下面的按钮,遍历对象person属性</p> <button onclick="myFunc()">点击这里</button> <p id="one"></p> <script> function myFunc() { let x; let text = ""; const person = { firstName: "Bill", lastName: "Gates", age: 56 }; for (x in person) { text = text + " " + person[x]; } document.getElementById("one").innerHTML = text; } </script> </body> </html> while循环 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>点击按钮,i小于5就会打印输出</p> <button onclick="myFunc()">点击这里</button> <p id="one">显示在这里</p> <script> function myFunc() { let x = "", i = 0; while (i < 5) { x = x + "这个数字为" + i + "<br>"; i++; } document.getElementById("one").innerHTML = x } </script> </body> </html> do/while循环 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>点击按钮,打印小于5的数</p> <button onclick="myFunc()">点击这里</button> <p id="one"></p> <script> function myFunc() { let x = ""; let i = 0; do { x = x + "该数字为" + i + "<br>"; i++; } while (i < 5); document.getElementById("one").innerHTML=x; } </script> </body> </html> for循环和while循环比较 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>这是funcOne</p> <button onclick="funcOne()">点击funcOne</button> <p id="one">funcOne在这里</p> <p>这是funcTwo</p> <button onclick="funcTwo()">点击funcTwo</button> <p id="two">funcTwo在这里</p> <script> function funcOne() { numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]; let i = 0; let addRes = 0; while (numbers[i]) { addRes += numbers[i]; i++; } document.getElementById("one").innerHTML = addRes + "<br>"; } function funcTwo() { numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]; let i = 0; let mulRes = 1; for (; numbers[i];) { mulRes *= numbers[i]; i++; } document.getElementById("two").innerHTML = mulRes + "<br>"; } </script> </body> </html> Break和Continue break 语句用于跳出循环。continue 用于跳过循环中的一个迭代。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>这是continue和break语句</p> <button onclick="funcOne()">点击funcOne</button> <p id="one">这是funcOne</p> <br> <br> <br> <br> <br> <br> <button onclick="funcTwo()">点击funcTwo</button> <p id="two">这是funcTwo</p> <script> function funcOne() { let x = ""; let i = 0; for (i = 0; i < 10; i++) { if (i < 5) { break; } x = x + "该数字为" + i + "<br>"; } document.getElementById("one").innerHTML = x; } function funcTwo() { let x = ""; let i = 0; for (i = 0; i < 10; i++) { if (i === 8) { continue; } x = x + "该数字为" + i + "<br>"; } document.getElementById("two").innerHTML = x; } </script> </body> </html> typeof、null和undefined使用typeof操作符来检测变量的数据类型。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p id="one"></p> <script> document.getElementById("one").innerHTML = typeof "john" + "<br>" + typeof 3.14 + "<br>" + typeof false + "<br>" + typeof [1, 2, 3, 4] + "<br>" + typeof {name: 'john', age: 34}; </script> </body> </html> 在JavaScript中,数组是一种特殊的对象类型。 因此 typeof [1,2,3,4] 返回 object。 null表示空,也就是”什么也没有“。当使用typeof 检测时,返回object。对象可以使用undefined来清空。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>one:</p> <p id="one"></p> <p>two:</p> <p id="two"></p> <script> var person = {firstName: "Bill", lastName: "Gates", age: 50}; var person = null; document.getElementById("one").innerHTML = typeof person; person = undefined document.getElementById("two").innerHTML = typeof person; </script> </body> </html> constructor属性constructor属性返回所有JavaScript变量的构造函数。可以使用constructor属性来查看对象是否为数组或者是否为日期 (包含字符串 "Date")等。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>constructor属性返回变量或者构造函数</p> <p id="one">HRER</p> <script> document.getElementById("one").innerHTML = "Hello".constructor + "<br>" + 3.14.constructor + "<br>" + false.constructor + "<br>" + [1, 2, 3].constructor + "<br>" + {name: "Hello", age: 18}.constructor + "<br>" + new Date().constructor + "<br>" + function () { }.constructor; </script> </body> </html> 类型转换JavaScript 变量可以转换为新变量或其他数据类型:
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>String()方法可以将数字转化为字符串</p> <p id="one">HERE</p> <p>toString()方法可以将数字转化为字符串</p> <p id="two">HERE</p> <script> let x = 123; document.getElementById("one").innerHTML = String(x) + "<br>" + String(123) + "<br>" + String(100 + 23); document.getElementById("two").innerHTML = x.toString() + "<br>" + (123).toString() + "<br>" + (100 + 123.2).toString(); </script> </body> </html> 一元运算符+Operator+可用于将变量转换为数字: <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <P>typeof操作符返回变量或者表达式类型</P> <button onclick="myFuncOne()">CLICK HERE ONE</button> <p id="one">HERE</p> <button onclick="myFuncTwo()">CLICK HERE TWO</button> <p id="two">HERE</p> <script> function myFuncOne() { let y = "5"; let x = +y; document.getElementById("one").innerHTML = typeof y + "<br>" + x + "<br>" + typeof x; } function myFuncTwo() { let a = "Hello"; let b = +a; document.getElementById("two").innerHTML = typeof a + "<br>" + b + "<br>" + typeof b; } </script> </body> </html>
正则表达式正则表达式(英语:Regular Expression,在代码中常简写为regex、regexp或RE)使用单个字符串来描述、匹配一系列符合某个句法规则的字符串搜索模式。 search() 用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,并返回子串的起始位置。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>收索字符串,匹配位置</p> <button onclick="myFuncOne()">CLICK HERE ONE</button> <p id="one">HERE</p> <button onclick="myFuncTwo()">CLICK HERE TWO</button> <p id="two">HERE</p> <script> function myFuncOne() { let str = "Hello,World!"; document.getElementById("one").innerHTML = str.search(/World/i); } function myFuncTwo() { let str = "Welcome to China!"; document.getElementById("two").innerHTML = str.search("China"); } </script> </body> </html> replace() 用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>正则表达式replace()替换</p> <button onclick="myFuncOne()">CLICK ONE</button> <p id="one">Hello,Java</p> <button onclick="myFuncTwo()">CLICK TWO</button> <p id="two">Hello,Java</p> <script> function myFuncOne() { let str = document.getElementById("one").innerHTML; document.getElementById("one").innerHTML = str.replace(/Java/i, "Python"); } function myFuncTwo() { let str = document.getElementById("two").innerHTML; document.getElementById("two").innerHTML = str.replace("Java","JavaScipt"); } </script> </body> </html> 正则表达式模式
test() 用于检测一个字符串是否匹配某个模式,如果字符串中含有匹配的文本,则返回true,否则返回false。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <script> let obj = new RegExp("e"); let boolOne = obj.test("Hello,This is JavaScript"); let boolTwo = obj.test("This is JavaScript"); document.write(boolOne + "<br>" + boolTwo); </script> </body> </html> exec() 用于检索字符串中的正则表达式的匹配,该函数返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <script> let obj = new RegExp(/e/); resOne = obj.exec("Hello,This is JavaScript"); resTwo = obj.exec("This is JavaScript"); /*没有就是null*/ document.write(resOne + "<br>" + resTwo); </script> </body> </html> 错误异常错误类型
try...catch try语句允许我们定义在执行时进行错误测试的代码块,catch语句允许我们定义当try代码块发生错误时,所执行的代码块。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <input type="button" value="查看消息" onclick="myFunc()"> <script> let txt = ""; function myFunc() { try { alert111("Hello,World!") } catch (err) { txt = "这里有一个错误\n\n"; txt += "错误描述:" + err.message + "\n\n"; txt += "点击确定继续\n\n"; alert(txt) } } </script> </body> </html> throw throw语句允许我们创建自定义错误。正确的技术术语是:创建或抛出异常(exception)。如果把throw与try和catch一起使用,那么您能够控制程序流,并生成自定义的错误消息。 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>请输入一个5-10之间的数字</p> <label for="one"></label><input id="one" type="text"> <button type="button" onclick="myFunc()">CLICK</button> <p id="message">HERE</p> <script> function myFunc() { let message; let x; message = document.getElementById("message"); message.innerHTML = ""; x = document.getElementById("one").value; try { if (x === "") throw "值为空"; if (isNaN(x)) throw "不是数字"; x = Number(x); if (x < 5) throw "太小"; if (x > 10) throw "太大"; } catch (error) { message.innerHTML = "错误" + error; } } </script> </body> </html> 函数调用JavaScript 函数有 4 种调用方式,每种方式的不同在于this的初始化。一般而言,在Javascript中,this指向函数执行时的当前对象。 调用1:作为一个函数调用 one function myFunc(a, b) { return a * b; } myFunc(1, 2); two function myFunc(a, b) { return a * b; } window.myFunc(1, 2); 调用2:函数作为方法调用 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>函数作为方法调用</p> <p id="one">HERE</p> <script> let myObject = { firstName: "Bill", lastName: "Gates", fullName: function () { return this.firstName + " " + this.lastName; } }; document.getElementById("one").innerHTML = myObject.fullName(); </script> </body> </html> 调用3:使用构造函数调用函数 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>该实例中,myFunc()是函数的构造函数</p> <p id="one"></p> <script> function myFunc(argOne, argTwo) { this.Name = argOne; this.Number = argTwo; } let x = new myFunc("Hello", 123); document.getElementById("one").innerHTML = x.Name; </script> </body> </html> 调用4:作为函数方法调动函数 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>作为函数方法调动函数</p> <p id="one">HERE</p> <script> let obj, array; function myFunc(a, b) { return a * b; } array = [5, 6]; obj = myFunc.apply(obj, array); document.getElementById("one").innerHTML = obj; </script> </body> </html> 闭包内嵌函数 实际上,在JavaScript中,所有函数都能访问它们上一层的作用域。JavaScript支持嵌套函数,嵌套函数可以访问上一层的函数变量。内嵌函数plus()可以访问父函数的counter变量: <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>内嵌函数</p> <p id="one">HERE</p> <script> document.getElementById("one").innerHTML = add(); function add() { let counter = 0; function plus() { counter += 1; } plus(); return counter; } </script> </body> </html> 闭包 函数的自我调用称为bibao <!DOCTYPE html> <html lang="zh-CN"> <head> <meta http-equiv="content-Type" charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <title>Title</title> </head> <body> <p>局部计数器</p> <button type="button" onclick="myFunc()">计数器</button> <p id="one">HERE</p> <script> let add = (function () { let counter = 0; return function () { return counter += 1; } })(); function myFunc() { document.getElementById("one").innerHTML = add(); } </script> </body> </html> 【相关推荐:javascript视频教程、web前端】 |
위 내용은 JavaScript의 기본 구문을 요약하고 정리합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!