跳到主要内容

JavaScript极简入门: 1. Hello JavaScript (2行代码)

WTF JavaScript 教程,帮助新人快速入门 JavaScript。

推特@WTFAcademy_@0xAA_Science

WTF Academy社群: 官网 wtf.academy | WTF Solidity教程 | discord | 微信群申请

所有代码和教程开源在github: github.com/WTFAcademy/WTF-JavaScript


2023年,WTF Academy 将开发一个零基础入门的 JavaScript 教程,帮助新人进入 Web3 开发。第一讲,我们将介绍什么是 JavaScript,并编写第一个JavaScript 程序:Hello JavaScript(两行代码)。

什么是 Javascript?

JavaScript 是一种用于与网页元素交互的轻量型编程语言。前端开发者可以将它与 HTML/CSS 结合并增强网页的功能,例如动态更新网页内容,网页交互等。现在,JavaScript 也可以在服务器(后端)通过 Node.js 运行,用于更新数据库、文件系统等。

JavaScript的历史

JavaScript是一种由Netscape公司在1995年开发的脚本语言。Netscape的布兰登·艾希(Brendan Eich)在仅仅10天内设计出了这种语言的初版,起初命名为Mocha,之后更名为LiveScript,最后在1995年底与Sun Microsystems公司联手宣布更名为JavaScript,当时的目的是与那时广受欢迎的Java语言相吸引。

尽管Java和JavaScript的名字相似,但两者在设计理念和语法上有着显著的差异。JavaScript设计之初主要是为了在浏览器中执行简单的任务,如表单验证、动画效果等,而Java是一种用于构建大型企业级应用的全功能编程语言。

1997年,JavaScript被提交到ECMA国际(European Computer Manufacturers Association)并成为ECMAScript的标准。这个标准从那时起就一直在不断的发展和进化,现在我们通常说的JavaScript其实就是遵循ECMAScript标准的语言。

为什么要学习JavaScript?

JavaScript在现代Web开发中起着至关重要的作用,它是浏览器中唯一的编程语言。主要的作用包括:

  1. 动态交互:JavaScript使网页具有动态性,例如,可以在用户不需要重新加载整个页面的情况下对网页的一部分进行更新,或响应用户的点击,滚动等操作。

  2. 操作DOM:JavaScript可以操作网页上的DOM元素,动态更改网页内容。

  3. 前端验证:JavaScript可以在数据发送到服务器之前进行前端验证,提高数据的正确性。

  4. Ajax通信:通过JavaScript的Ajax,我们可以在后台与服务器进行数据交互,创建动态而且实时的网页。

近年来,JavaScript的使用范围已经扩展到了浏览器之外。例如,Node.js是一个基于JavaScript的开源服务器框架,使得JavaScript也可以用于服务器端的开发。而React Native、Ionic等框架则让JavaScript成为了移动应用开发的工具。同时,很多新兴的前端框架和库,如React.js、Vue.js、Angular.js都是基于JavaScript的,极大地推动了前端开发的进步。

根据2022年Stack Overflow社区年度调查显示,JavaScript 已经连续十年成为最受开发者欢迎的一门编程语言。学习 JavaScript 不仅是普通 web 开发者的必备技能,同时也是全栈 web3 学习者的必要知识。

1-1

JavaScript与其他语言的比较

虽然JavaScript和其他编程语言(例如Python和Java)在语法和设计上存在一些差异,但JavaScript的基本组件(如变量,函数,循环和条件语句)与其他语言非常相似。然而,JavaScript有一些独特的特性,使得它在Web开发领域独树一帜。

  • 动态类型:JavaScript是一种动态类型的语言,这意味着你不需要预先声明变量的类型。一个变量可能开始时是一个数字,稍后可以变成一个字符串。

  • 解释型语言:与需要先编译后运行的语言(如C++和Java)不同,JavaScript是一种解释型语言。这意味着代码在运行时被解释和执行,不需要进行预编译。

  • 基于原型的对象模型:不同于基于类的语言(如Java),JavaScript使用的是基于原型的对象模型。在JavaScript中,对象可以继承其他对象的属性,称为原型链。

  • 第一类函数:在JavaScript中,函数是第一类对象,这意味着函数可以作为其他函数的参数,也可以作为其他函数的返回值。

开发工具

1. playcode.io

playcode是一个JavaScript的在线编译平台,你不需要在本地安装任何程序就可以运行.js文件,非常方便。本教程将使用 playcode 进行代码演示,未来也将在 wtf.academy 的教程中嵌入可互动代码模块。你可以在链接上找到这一讲的代码。

2. VS Code & WebStorm

你可以使用本地 VS CodeWebStorm进行开发,需要安装Node.js,我们会在之后的章节介绍如何使用它。

Hello JavaScript!

下面,我们要写第一个 JavaScript 程序:Hello JavaScript。在这个程序中,我们定义了一个变量,并将它的值输出到控制台。

代码:

let hello = "Hello JavaScript!";
console.log(hello);

输出:

1-2

下面,我们逐行学习一下。

  1. 第 1 行,我们利用 let 关键字定义了一个名为 hello 的变量,并将"Hello JavaScript!" 赋值给它,最后以分号 ; 结束这一行语句。

    let hello = "Hello JavaScript!";
  2. 第 2 行,我们利用内置函数 console.loghello 变量的值输出到控制台,让人们可以看到。

    console.log(hello);

【拓展知识】Javascript 程序是如何运行的?

你不理解下面这段话也没关系,不妨碍你继续学习 JavaScript,因为我也不是很理解!

如果说编程语言是人类与机器沟通的语言,那么程序是一篇篇文章,代码是其中的文本。Javascript 程序运行的大致步骤如下:

  1. 程序员完成一段代码。

    let hello = "Hello JavaScript!";
  2. 将代码提交给编译器(compiler)编译。首先,编译器会将代码分解为单个的令牌(token)。上面的语句会被分解为 5 个令牌: let, hello, =, "Hello JavaScript!", 和

  3. 接下来,令牌会被重新组织成一个树状结构,也叫抽象语法树(Abstract Syntax Tree, AST)。你可以在AstExplorer上输入代码,并查看生成的抽象语法树

  4. 最后,编译器会将结构化的抽象语法树转换并生成计算机能运行的的机器码

如果你的代码没有按照编程语言的语法来写,编译器就无法把它解析为机器能懂的机器码,那么程序就无法运行。这时,你就要去找出程序的bug并修复它。在未来的教程中,我们将介绍更多的 JavaScript 语法。

习题

Hello Javascript 程序中变量 hello 的值改为 “Hello WTF Academy!”,并观察控制台的输出。

总结

第一讲,我们介绍了什么是 JavaScript,为什么要学习它,JavaScript 开发工具,并编写了第一个仅有两行的 JavaScript 程序:Hello JavaScript。接下来,我们将继续 JavaScript 之旅!