JavaScript 基础语法

JavaScript 是一种动态类型语言,变量声明使用 varletconstletconst 是 ES6 引入的块级作用域变量声明方式。

javascript 复制代码
let name = "John";
const age = 25;
var isStudent = true;

数据类型

JavaScript 包含以下基本数据类型:

  • 字符串(String)
  • 数字(Number)
  • 布尔值(Boolean)
  • null
  • undefined
  • 对象(Object)
  • Symbol(ES6 新增)
javascript 复制代码
typeof "Hello"; // "string"
typeof 42;      // "number"
typeof true;    // "boolean"

函数定义

函数可以通过多种方式定义:

javascript 复制代码
// 函数声明
function greet(name) {
    return `Hello, ${name}!`;
}

// 函数表达式
const greet = function(name) {
    return `Hello, ${name}!`;
};

// 箭头函数(ES6)
const greet = (name) => `Hello, ${name}!`;

对象和数组

对象用于存储键值对集合:

javascript 复制代码
const person = {
    name: "Alice",
    age: 30,
    greet: function() {
        console.log(`My name is ${this.name}`);
    }
};

数组用于存储有序数据:

javascript 复制代码
const numbers = [1, 2, 3, 4, 5];
numbers.push(6); // 添加元素
numbers.forEach(num => console.log(num));

DOM 操作

JavaScript 可以操作网页元素:

javascript 复制代码
// 获取元素
const btn = document.getElementById("myButton");

// 添加事件监听
btn.addEventListener("click", function() {
    console.log("Button clicked");
});

// 修改内容
document.querySelector(".content").textContent = "New content";

异步编程

处理异步操作的几种方式:

javascript 复制代码
// 回调函数
setTimeout(() => {
    console.log("Delayed message");
}, 1000);

// Promise
fetch("https://api.example.com/data")
    .then(response => response.json())
    .then(data => console.log(data))
    .catch(error => console.error(error));

// async/await
async function getData() {
    try {
        const response = await fetch("https://api.example.com/data");
        const data = await response.json();
        console.log(data);
    } catch (error) {
        console.error(error);
    }
}

ES6+ 特性

现代 JavaScript 的重要特性:

  • 模板字符串
  • 解构赋值
  • 默认参数
  • 展开运算符
  • 类语法
javascript 复制代码
// 解构赋值
const { name, age } = person;

// 类
class Person {
    constructor(name) {
        this.name = name;
    }

    greet() {
        console.log(`Hello, ${this.name}`);
    }
}

模块化

ES6 模块系统:

javascript 复制代码
// module.js
export const PI = 3.14159;
export function circleArea(r) {
    return PI * r * r;
}

// app.js
import { PI, circleArea } from "./module.js";
console.log(circleArea(5));
相关推荐
郑州光合科技余经理20 小时前
同城系统海外版:一站式多语种O2O系统源码
java·开发语言·git·mysql·uni-app·go·phpstorm
一只乔哇噻20 小时前
java后端工程师+AI大模型开发进修ing(研一版‖day60)
java·开发语言·人工智能·学习·语言模型
LNN202220 小时前
Linuxfb+Qt 输入设备踩坑记:解决 “节点存在却无法读取“ 问题
开发语言·qt
foxsen_xia21 小时前
go(基础06)——结构体取代类
开发语言·算法·golang
巨人张21 小时前
C++火柴人跑酷
开发语言·c++
ID_1800790547321 小时前
基于 Python 的 Cdiscount 商品详情 API 调用与 JSON 核心字段解析(含多规格 SKU 提取)
开发语言·python·json
悟能不能悟1 天前
Caused by: java.sql.SQLException: ORA-28000: the account is locked怎么处理
java·开发语言
亦是远方1 天前
南京邮电大学使用计算机求解问题实验一(C语言简单编程练习)
c语言·开发语言·实验报告·南京邮电大学
我是哈哈hh1 天前
【Python数据分析】Numpy总结
开发语言·python·数据挖掘·数据分析·numpy·python数据分析
Michelle80231 天前
24大数据 14-2 函数练习
开发语言·python