从0开始学习JavaScript--JavaScript基础

news2025/1/24 14:48:42

JavaScript作为一门前端编程语言,在现代web开发中扮演着不可替代的角色。它不仅为网页增添了动态和交互性,而且随着Node.js的崛起,也在服务器端开发中占据了重要地位。在本章节中,我们将探讨JavaScript的作用、重要性以及与其他前端语言的关系。

JavaScript的作用和重要性

JavaScript最初由Netscape公司开发,旨在使网页具有更强大的交互性。随着时光的推移,它逐渐演变成一门多用途的编程语言,涵盖了前端开发、后端开发以及移动应用开发等多个领域。

作用:

  • 前端交互性: JavaScript通过操作DOM(文档对象模型)实现网页内容的动态更新,从而提供更丰富的用户体验。

  • 异步通信: AJAX(Asynchronous JavaScript and XML)技术的兴起使得JavaScript能够异步地与服务器通信,不必重新加载整个页面,提高了性能和用户感知。

  • 后端开发: 随着Node.js的出现,JavaScript开始被广泛应用于服务器端开发,使得前端和后端可以使用同一种语言,简化了全栈开发的流程。

  • 移动应用开发: 框架如React Native和Ionic使得开发者能够使用JavaScript构建原生移动应用,跨足多个平台。

  • 大前端时代: 随着前端技术的不断演进,JavaScript在现代web开发中扮演着核心角色,涵盖了大前端时代的各个方面。

重要性:

  • 用户体验提升: JavaScript使得网页可以实时响应用户操作,创建动画效果,从而提高用户体验。

  • 全栈开发: JavaScript不仅仅限于前端,通过Node.js,它也在后端发挥着巨大的作用,实现了全栈开发的概念。

  • 跨平台应用: JavaScript的跨平台特性使得开发者能够用同一套代码构建适用于不同平台的应用程序,提高了开发效率。

JavaScript与其他前端语言的关系

在前端开发中,JavaScript与HTML和CSS紧密合作,共同构成了现代web应用的基石。

  • HTML(超文本标记语言): HTML负责定义网页的结构和内容,而JavaScript则通过操作DOM,实现对HTML元素的动态修改。

  • CSS(层叠样式表): CSS负责定义网页的样式和布局,而JavaScript可以通过操作CSS属性,实现对样式的动态调整。

JavaScript与这两者的关系可以形象地比喻为三者是web开发的三大支柱,共同构建了现代动态、交互性的网页。

基本语法与数据类型

在这一章节中,将深入了解JavaScript的基本语法和数据类型。这是学习JavaScript的起点,了解这些基础概念对于构建更复杂的程序至关重要。

1 JavaScript语法概述

JavaScript的语法类似于其他C家族的语言,是一种弱类型语言。以下是一些基本的语法概念:

  • 语句: JavaScript程序是由一条条语句组成的,每个语句以分号(;)结尾。
// 示例:声明变量并赋值
let x = 5;
console.log(x);
  • 注释: 使用//表示单行注释,使用/* */表示多行注释。
// 这是单行注释

/*
  这是
  多行
  注释
*/

2 变量、常量与数据类型

在JavaScript中,变量用于存储数据值,而常量是不可变的。JavaScript有多种数据类型,包括基本数据类型和引用数据类型。

变量声明与赋值:

let variableName = "Hello, JavaScript!";
const constantValue = 42;

数据类型:

基本数据类型: 包括数字(Number)、字符串(String)、布尔值(Boolean)、空(Null)、未定义(Undefined)。

let numberValue = 42;
let stringValue = "Hello, World!";
let booleanValue = true;
let nullValue = null;
let undefinedValue;

引用数据类型: 包括对象(Object)、数组(Array)、函数(Function)等。

let objectValue = { key: "value" };
let arrayValue = [1, 2, 3];
function sayHello() {
  console.log("Hello!");
}

3 操作符和表达式

JavaScript支持多种操作符,用于进行各种操作,例如算术运算、比较运算和逻辑运算。

算术运算符:

let x = 5;
let y = 3;

let sum = x + y; // 加法
let difference = x - y; // 减法
let product = x * y; // 乘法
let quotient = x / y; // 除法
let remainder = x % y; // 取余

比较运算符:

let a = 5;
let b = "5";

console.log(a == b); // 相等
console.log(a === b); // 严格相等(值和类型都相等)
console.log(a != b); // 不相等
console.log(a !== b); // 不严格相等

逻辑运算符:

let isTrue = true;
let isFalse = false;

console.log(isTrue && isFalse); // 与运算
console.log(isTrue || isFalse); // 或运算
console.log(!isTrue); // 非运算

4 控制流程语句

JavaScript提供了多种控制流程语句,用于根据条件执行不同的代码块。

if语句:

let num = 10;

if (num > 0) {
  console.log("正数");
} else if (num < 0) {
  console.log("负数");
} else {
  console.log("零");
}

for循环:

for (let i = 0; i < 5; i++) {
  console.log(i);
}

while循环:

let count = 0;

while (count < 3) {
  console.log(count);
  count++;
}

函数与作用域

在JavaScript中,函数是一种重要的构建块,它们不仅用于组织代码,还能够实现复杂的逻辑和操作。本章将深入探讨函数的定义与调用、函数参数与返回值、作用域与闭包的概念,以及this关键字的作用。

1 函数的定义与调用

函数的定义:

// 基本的函数定义
function greet() {
  console.log("Hello, JavaScript!");
}

// 带参数的函数定义
function greetPerson(name) {
  console.log("Hello, " + name + "!");
}

// 匿名函数
let square = function(x) {
  return x * x;
};

函数的调用:

// 调用无参数函数
greet();

// 调用带参数函数
greetPerson("Alice");

// 调用匿名函数
let result = square(4);
console.log(result); // 输出:16

2 函数参数与返回值

函数参数:

function add(x, y) {
  return x + y;
}

// 调用函数并传递参数
let sum = add(3, 7);
console.log(sum); // 输出:10

函数返回值:

function multiply(x, y) {
  return x * y;
}

let product = multiply(2, 5);
console.log(product); // 输出:10

3 作用域与闭包的概念

作用域:

作用域定义了变量和函数的可访问性。JavaScript有全局作用域和局部作用域。

let globalVariable = "I'm global!"; // 全局变量

function scopeExample() {
  let localVariable = "I'm local!"; // 局部变量
  console.log(globalVariable); // 可访问全局变量
  console.log(localVariable); // 可访问局部变量
}

scopeExample();
console.log(globalVariable); // 仍然可访问全局变量
// console.log(localVariable); // 无法访问局部变量,将会报错

闭包:

闭包是指在一个函数内部定义的函数,并且内部函数可以访问外部函数的变量。这使得外部函数的局部变量在外部函数执行完后仍然可以被内部函数引用。

function outerFunction() {
  let outerVariable = "I'm outer!";

  function innerFunction() {
    console.log(outerVariable); // 内部函数可以访问外部函数的变量
  }

  return innerFunction;
}

let closure = outerFunction();
closure(); // 输出:I'm outer!

4 this关键字的作用

在JavaScript中,this关键字用于引用当前执行上下文中的对象。其值的具体含义取决于函数的调用方式。

let person = {
  name: "John",
  greet: function() {
    console.log("Hello, " + this.name + "!");
  }
};

person.greet(); // 输出:Hello, John!

在这个例子中,this关键字指向了包含它的对象,即person对象。然而,当函数以不同的方式调用时,this的值可能会有所不同。这是JavaScript中一个较为复杂的概念,需要根据具体的使用场景进行深入研究。

数组与对象

在JavaScript中,数组和对象是两种重要的数据结构,它们分别用于存储有序和无序的数据集。本章将深入探讨数组的创建与操作、对象的定义与属性访问,以及JSON格式与对象序列化的概念。

1 数组的创建与操作

数组的创建:

// 创建空数组
let emptyArray = [];

// 创建包含元素的数组
let numbers = [1, 2, 3, 4, 5];

// 创建混合类型的数组
let mixedArray = [1, "two", true, { key: "value" }];

// 使用构造函数创建数组
let anotherArray = new Array(1, 2, 3);

数组的操作:

// 获取数组长度
let length = numbers.length;

// 访问数组元素
let firstElement = numbers[0];
let lastElement = numbers[numbers.length - 1];

// 添加元素到数组末尾
numbers.push(6);

// 删除数组末尾的元素
let poppedElement = numbers.pop();

// 在数组开头添加元素
numbers.unshift(0);

// 删除数组开头的元素
let shiftedElement = numbers.shift();

// 查找元素在数组中的索引
let index = numbers.indexOf(3);

2 对象的定义与属性访问

对象的定义:

// 创建空对象
let emptyObject = {};

// 创建包含属性的对象
let person = {
  name: "John",
  age: 30,
  gender: "male"
};

// 使用构造函数创建对象
let anotherPerson = new Object();
anotherPerson.name = "Alice";
anotherPerson.age = 25;

属性访问:

// 访问对象属性
let personName = person.name;
let personAge = person["age"];

// 修改对象属性
person.age = 31;

// 添加新属性
person.job = "developer";

// 删除属性
delete person.gender;

3 JSON格式与对象序列化

JSON格式:

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。在JavaScript中,对象可以通过JSON.stringify()方法转换为JSON格式的字符串。

let book = {
  title: "JavaScript Guide",
  author: "John Doe",
  price: 20
};

let jsonBook = JSON.stringify(book);
console.log(jsonBook);

对象序列化与反序列化:

// 对象序列化
let serializedBook = JSON.stringify(book);

// 对象反序列化
let deserializedBook = JSON.parse(serializedBook);
console.log(deserializedBook.title); // 输出:JavaScript Guide

异步编程与事件驱动

在JavaScript中,异步编程和事件驱动是处理用户交互和处理非阻塞任务的关键概念。本章将深入讨论异步编程模型、回调函数与Promise、事件驱动编程,以及定时器与延迟执行。

1 异步编程模型

在JavaScript中,异步编程是为了避免阻塞主线程而引入的一种执行方式。常见的异步操作包括网络请求、文件读取、定时器等。

回调函数:

function fetchData(callback) {
  setTimeout(function() {
    let data = "Async data";
    callback(data);
  }, 1000);
}

fetchData(function(result) {
  console.log(result);
});

Promise:

function fetchData() {
  return new Promise(function(resolve, reject) {
    setTimeout(function() {
      let data = "Async data";
      resolve(data);
    }, 1000);
  });
}

fetchData().then(function(result) {
  console.log(result);
});

2 回调函数与Promise

回调函数:

function fetchData(callback) {
  setTimeout(function() {
    let data = "Async data";
    callback(data);
  }, 1000);
}

fetchData(function(result) {
  console.log(result);
});

Promise:

function fetchData() {
  return new Promise(function(resolve, reject) {
    setTimeout(function() {
      let data = "Async data";
      resolve(data);
    }, 1000);
  });
}

fetchData().then(function(result) {
  console.log(result);
});

3 事件驱动编程

事件驱动编程是JavaScript中常见的一种模型,特别是在处理用户交互和浏览器事件时。

// 事件监听
document.getElementById("myButton").addEventListener("click", function() {
  console.log("Button clicked!");
});

4 定时器与延迟执行

定时器用于延迟执行代码块或循环执行代码。

setTimeout

setTimeout(function() {
  console.log("Delayed execution");
}, 2000);

setInterval

let counter = 0;

let intervalId = setInterval(function() {
  console.log("Count: " + counter);
  counter++;

  if (counter === 5) {
    clearInterval(intervalId);
  }
}, 1000);

总结

JavaScript是一门强大的编程语言,广泛应用于前端开发、后端开发以及移动应用开发。本文通过深入探讨JavaScript的基本语法、数据类型、函数与作用域、数组与对象、异步编程与事件驱动等核心概念,提供了全面的学习指南。

本文分享了JavaScript的基础语法和数据类型,包括变量、常量、操作符以及控制流程语句。这为构建简单到复杂的程序奠定了基础。接着,深入研究了函数的定义与调用、函数参数与返回值、作用域与闭包以及this关键字的使用,能够更好地组织和管理代码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1210877.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

23款奔驰E300L升级几何多光束大灯 自适应远近功能

奔驰新款E300L升级几何多光束大灯&#xff0c;单侧的LED头灯分别由84颗独立的LED光源组成&#xff0c;与风挡玻璃上的立体摄像机配合&#xff0c;每秒钟可对路况进行100次扫描&#xff0c;针对不同的路况和驾驶状态&#xff0c;智能调整84个独立光源 几何多光束大灯每侧大灯都拥…

rocketmq一主多从搭建

1.四台服务器192.168.4.202&#xff08;master&#xff09;&#xff0c;192.168.4.203&#xff0c;192.168.4.204&#xff0c;192.168.4.205 分别在四台机子上跑namesrv&#xff0c;无需修改参数及启动命令&#xff0c;官方默认启动即可。 2. broker 以下内容复制到4台机子的…

如何用AI交互数字人打造数智文旅?

随着旅游业不断发展壮大&#xff0c;景区的功能不断扩展、业态不断延伸、硬件不断升级&#xff0c;但如何利用自身文旅资源打造差异化、数智化文旅景点&#xff0c;吸引游客与市民成为一大经营痛点。 而AI交互数字人的出现&#xff0c;可以极大地将文旅资源以可视化、具象化的…

Vatee万腾智能创新探索:Vatee科技引领创新发展

在Vatee万腾的智能创新探索中&#xff0c;我们见证了一场科技领域的革命。Vatee万腾通过其独到的智能时代愿景&#xff0c;正引领着科技创新发展的浪潮&#xff0c;塑造着未来的数字化格局。 Vatee万腾以其卓越的科技引领力&#xff0c;将智能创新推向新的高度。通过整合先进的…

源码级JVS低代码功能新增:动态配置、逻辑多级循环嵌套等等

低代码更新功能 新增: 1.下拉组件选项新增动态配置&#xff1b; 选项的内容可以根据特定的条件或数据源进行动态变化的功能&#xff0c;通过动态配置&#xff0c;用户可以灵活地设置下拉组件的选项内容&#xff0c;例如从数据库或其他数据源中获取选项数据&#xff0c;或者根…

AXglyph——轻量级科研绘图软件

今天博主将推荐一款简约却不简单的制图软件——axglyph。 AxGlyph是一款十分优秀的矢量绘图软件&#xff0c;官方版界面简洁&#xff0c;功能强大&#xff0c;支持自由矢量画笔、混合矢量路径和矢量漫水填充。支持自由定义的磁力点阵&#xff0c;支持插图编号及引用管理&#…

idea启动类运行后报错:Port 6380 was already in use.

问题原因&#xff1a; idea窗口中某个项目还在启动中时 误关了窗口&#xff0c;导致在其他项目运行时报错端口被占用 解决办法&#xff1a; 先杀掉占用端口&#xff0c;再重新启动 步骤如下&#xff1a; 1.先找到6380端口对应pid winr打开cmd命令行窗口 输入命令&#xf…

RT-Thread STM32F407 DMA

这里以串口的DMA方式接收为例&#xff0c;串口1进行调试&#xff0c;串口2进行DMA接收 第一步&#xff0c;进入RT-Thread Settings配置DMA 第二步&#xff0c;进入board.h&#xff0c;定义串口及DMA宏 第三步&#xff0c;回到main.c&#xff0c;配置串口及DMA模式 第四步…

c# 字符串转化成语音合成,System.Speech

C# 语音合成可以使用 System.Speech.Synthesis 命名空间中的 SpeechSynthesizer 类来实现。SpeechSynthesizer 类提供了一系列方法和属性&#xff0c;可以用来控制语音合成的过程&#xff0c;包括设置语音、音调、语速等。 下面是一个简单的示例&#xff0c;用来演示如何使用 …

专业的SRM系统全流程管理服务

一、什么是SRM系统 SRM系统&#xff0c;即供应商关系管理&#xff0c;是供应链管理中的重要组成部分&#xff0c;帮助企业与供应商建立、维护和改善业务关系&#xff0c;以实现双方共赢。本文将从供应商寻源到合同签订、订单履行、到付款及供应商评价等环节&#xff0c;阐述SR…

基于SSM的宠物综合服务平台的设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…

NineData慢查询分析:数据库性能优化的专家

在日常的数据库运维中&#xff0c;慢查询是一个常见的问题&#xff0c;它可能由复杂的查询语句、不充分的索引设计、大量数据的处理、硬件资源不足等多种因素引起。这些慢查询会消耗大量的数据库服务器资源&#xff0c;甚至可能导致数据库死机&#xff0c;无法响应业务请求。因…

infercnv

文章目录 brief安装使用体验输入文件制作运行试试吧结果部分others brief InferCNV is used to explore tumor single cell RNA-Seq data to identify evidence for somatic large-scale chromosomal copy number alterations, such as gains or deletions of entire chromoso…

程序员的护城河:技术深度与软实力的并重

程序员的护城河&#xff1a;技术深度与软实力的并重 作为一名资深的IT行业从业者&#xff0c;我一直在思考一个问题&#xff1a;在我们这个以数据驱动和技术创新为核心的时代&#xff0c;程序员的价值究竟体现在哪里&#xff1f;毫无疑问&#xff0c;程序员在维护系统安全、数…

易基因:综合全基因组DNA甲基化和转录组学分析鉴定调控骨骼肌发育潜在基因 | 研究进展

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。 DNA甲基化是骨骼肌发育中关键的表观遗传调控机制。但胚胎鸭骨骼肌发育中负责DNA甲基化的调控因子仍然未知。 2023年10月23日&#xff0c;南京农业大学动物科技学院于敏莉副教授团队在《…

PP-YOLOv2: A Practical Object Detector(2021.4)

文章目录 Abstract1. Introduction2. Revisit PP-YOLOPre-ProcessingBaseline ModelTraining Schedule 3. Selection of RefinementsPath Aggregation Network Mish Activation FunctionLarger Input SizeIoU Aware Branch 4. Experiments6. Conclusions 原文地址 源代码 Abstr…

Flink(五)【DataStream 转换算子(上)】

前言 这节注定是一个大的章节&#xff0c;我预估一下得两三天&#xff0c;涉及到的一些东西不懂就重新学&#xff0c;比如 Lambda 表达式&#xff0c;我只知道 Scala 中很方便&#xff0c;但在 Java 中有点发怵了&#xff1b;一个接口能不能 new 来构造对象? 答案是可以的&…

解决 requests 库下载文件问题的技术解析

在一个使用requests库的conda食谱构建过程中&#xff0c;我们注意到存在一个文件下载问题。该文件是从https://dakota.sandia.gov/sites/default/files/distributions/public/dakota-6.5-public.src.tar.gz下载的。使用curl和urllib2库可以正确下载文件&#xff0c;但使用reque…

Find My平衡车|苹果Find My技术与平衡车结合,智能防丢,全球定位

随着人们环保意识的加强&#xff0c;电动车的数量与日俱增。与此同时&#xff0c;科学家经过潜心的研究&#xff0c;终于开发出新款两轮电动平衡车。两轮电动平衡车是一种新型的交通工具&#xff0c;它与电动自行车和摩托车车轮前后排列方式不同&#xff0c;而是采用两轮并排固…

「Verilog学习笔记」优先编码器Ⅰ

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点&#xff0c;刷题网站用的是牛客网 分析 分析编码器的功能表&#xff1a; 当使能El1时&#xff0c;编码器工作&#xff1a;而当E10时&#xff0c;禁止编码器工作&#xff0c;此时不论8个输入端为何种状态&…