关于JavaScript技术的基础内容汇总

目录

  • JavaScript 基础知识
  • 1. JavaScript 基本语法
  • 2. 变量和常量
  • 3. 数据类型
  • 4. 运算符
  • 5. 控制结构
  • 6. 函数
  • 7. 对象
  • 8. 数组
  • 9. 事件处理
  • 10. DOM 操作

JavaScript 基础知识

学习 JavaScript(简称 JS)是前端开发的重要组成部分,它是一种动态的、弱类型的脚本语言,用于实现网页的交互功能。以下是学习 JavaScript 过程中需要掌握的基本概念、符号和对应的意义。
在这里插入图片描述

1. JavaScript 基本语法

  • 语句和分号

    • 语句是 JavaScript 程序的基本单位。每个语句通常以分号(;)结束,但在许多情况下,分号可以省略。
    • 示例:let x = 5;
  • 注释

    • 单行注释:以 // 开头。
      // 这是一个单行注释
      
    • 多行注释:以 /* 开头,以 */ 结束。
      /*
        这是一个多行注释
      */
      

2. 变量和常量

  • 变量声明
    • var:声明一个变量(不推荐使用,可能引发作用域问题)。
    • let:声明一个块级作用域的变量(推荐使用)。
    • const:声明一个块级作用域的常量,一旦赋值不能再改变。
    • 示例:
      var a = 10;
      let b = 20;
      const c = 30;
      

3. 数据类型

  • 基本数据类型

    • Number:数字类型。
      let num = 42;
      
    • String:字符串类型。
      let str = "Hello, world!";
      
    • Boolean:布尔类型。
      let isTrue = true;
      
    • Undefined:未定义类型。
      let undef;
      
    • Null:空值类型。
      let empty = null;
      
  • 复合数据类型

    • Object:对象类型。
      let obj = { name: "Alice", age: 25 };
      
    • Array:数组类型。
      let arr = [1, 2, 3, 4, 5];
      
    • Function:函数类型。
      function greet() {
        console.log("Hello!");
      }
      

4. 运算符

  • 算术运算符

    • +:加法。
    • -:减法。
    • *:乘法。
    • /:除法。
    • %:取模。
    • ++:自增。
    • --:自减。
    • 示例:
      let x = 10;
      let y = x + 5; // 15
      
  • 赋值运算符

    • =:赋值。
    • +=:加赋值。
    • -=:减赋值。
    • *=:乘赋值。
    • /=:除赋值。
    • %=:模赋值。
    • 示例:
      let x = 10;
      x += 5; // x 现在是 15
      
  • 比较运算符

    • ==:相等。
    • !=:不等。
    • ===:严格相等(值和类型都相等)。
    • !==:严格不等(值和类型都不相等)。
    • >:大于。
    • <:小于。
    • >=:大于或等于。
    • <=:小于或等于。
    • 示例:
      let x = 5;
      let y = 10;
      console.log(x < y); // true
      
  • 逻辑运算符

    • &&:与。
    • ||:或。
    • !:非。
    • 示例:
      let x = true;
      let y = false;
      console.log(x && y); // false
      

5. 控制结构

  • 条件语句

    • if 语句
      if (condition) {
        // 执行代码块
      }
      
    • if...else 语句
      if (condition) {
        // 执行代码块
      } else {
        // 执行代码块
      }
      
    • if...else if...else 语句
      if (condition1) {
        // 执行代码块
      } else if (condition2) {
        // 执行代码块
      } else {
        // 执行代码块
      }
      
  • 循环语句

    • for 循环
      for (let i = 0; i < 10; i++) {
        console.log(i);
      }
      
    • while 循环
      let i = 0;
      while (i < 10) {
        console.log(i);
        i++;
      }
      
    • do...while 循环
      let i = 0;
      do {
        console.log(i);
        i++;
      } while (i < 10);
      
  • switch 语句

    let x = 2;
    switch (x) {
      case 1:
        console.log("One");
        break;
      case 2:
        console.log("Two");
        break;
      default:
        console.log("Other");
        break;
    }
    

6. 函数

  • 函数声明
    function add(a, b) {
      return a + b;
    }
    
  • 函数表达式
    const add = function(a, b) {
      return a + b;
    };
    
  • 箭头函数
    const add = (a, b) => a + b;
    

7. 对象

  • 创建对象

    let person = {
      name: "John",
      age: 30,
      greet: function() {
        console.log("Hello, " + this.name);
      }
    };
    
  • 访问对象属性

    console.log(person.name); // John
    console.log(person["age"]); // 30
    
  • 修改对象属性

    person.name = "Jane";
    

8. 数组

  • 创建数组

    let numbers = [1, 2, 3, 4, 5];
    
  • 访问数组元素

    console.log(numbers[0]); // 1
    
  • 数组方法

    • push:在数组末尾添加一个元素。
      numbers.push(6);
      
    • pop:移除数组末尾的元素。
      numbers.pop();
      
    • shift:移除数组第一个元素。
      numbers.shift();
      
    • unshift:在数组开头添加一个元素。
      numbers.unshift(0);
      
    • forEach:对数组的每个元素执行一次提供的函数。
      numbers.forEach(function(number) {
        console.log(number);
      });
      

9. 事件处理

  • 添加事件监听

    document.getElementById("myButton").addEventListener("click", function() {
      alert("Button clicked!");
    });
    
  • 移除事件监听

    function clickHandler() {
      alert("Button clicked!");
    }
    document.getElementById("myButton").addEventListener("click", clickHandler);
    document.getElementById("myButton").removeEventListener("click", clickHandler);
    

10. DOM 操作

  • 选择元素

    • getElementById
      document.getElementById("myElement");
      
    • getElementsByClassName
      document.getElementsByClassName("myClass");
      
    • querySelector
      document.querySelector(".myClass");
      
  • 修改元素内容

    document.getElementById("myElement").innerText = "New content";
    document.getElementById("myElement").innerHTML = "<b>New content</b>";
    
  • 修改元素样式

    document.getElementById("myElement").style.color = "red";
    
  • 创建和添加元素

    let newElement = document.createElement("div");
    newElement.innerText = "Hello, World!";
    document.body.appendChild(newElement);
    ``
    

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【c语言】指针就该这么学(3)

&#x1f31f;&#x1f31f;作者主页&#xff1a;ephemerals__ &#x1f31f;&#x1f31f;所属专栏&#xff1a;C语言 目录 一、函数指针 1.函数指针变量的创建 2.函数指针变量的使用 二、typedef关键字 三、函数指针数组 1.函数指针数组的概念 2.函数指针数…

【操作系统】进程与线程的区别及总结(非常非常重要,面试必考题,其它文章可以不看,但这篇文章最后的总结你必须要看,满满的全是干货......)

目录 一、 进程1.1 PID(进程标识符)1.2 内存指针1.3 文件描述符表1.4 状态1.5 优先级1.6 记账信息1.7 上下文 二、线程三、总结&#xff1a;进程和线程之间的区别&#xff08;非常非常非常重要&#xff0c;面试必考题&#xff09; 一、 进程 简单来介绍一下什么是进程&#xf…

[UE 虚幻引擎] DTLoadFbx 运行时加载FBX本地模型插件说明

本插件可以在打包后运行时动态加载FBX模型。 新建一个Actor 并添加一个 DT Runtime Fbx Component。 然后直接调用组件的函数 LoadFile 加载显示模型&#xff08;注&#xff1a;不支持模型动画&#xff09; FilePath : 加载模型的绝对路径。 Create Collision : 是否创建碰撞…

R语言探索与分析19-CPI的分析和研究

一、选题背景 CPI&#xff08;居民消费价格指数&#xff09;作为一个重要的宏观经济指标&#xff0c;扮演着评估通货膨胀和居民生活水平的关键角色。在湖北省这个经济活跃的地区&#xff0c;CPI的波动对于居民生活、企业经营以及政府宏观经济政策制定都具有重要的影响。因此&a…

单链表的排序

对一个单链表进行排序。 方法一&#xff1a;构造一个辅助的数组来排序。 Java构造一个集合来存储。先将链表内容存储到集合中去&#xff0c;再对集合进行排序&#xff0c;最后按照顺序取出集合中的数据即可。 public ListNode sortInLit(ListNode head) {if (head null || he…

Solon2分布式事件总线的应用价值探讨

随着现代软件系统的复杂性日益增加&#xff0c;微服务架构逐渐成为开发大型应用的主流选择。在这种架构下&#xff0c;服务之间的通信和协同变得至关重要。Solon2作为一个高性能的Java微服务框架&#xff0c;其分布式事件总线&#xff08;Distributed Event Bus&#xff09;为微…

国标GB/T 28181详解:国标GBT28181-2022的客户端主动发起历史视音频回放流程

目录 一、定义 二、作用 1、提供有效的数据回顾机制 2、增强监控系统的功能性 3、保障数据传输与存储的可靠性 4、实现精细化的操作与控制 5、促进监控系统的集成与发展 三、历史视音频回放的基本要求 四、命令流程 1、流程图 2、流程描述 五、协议接口 1、会话控…

网络空间安全数学基础·多项式环与有限域

5.1 多项式环&#xff08;掌握&#xff09; 5.2 多项式剩余类环&#xff08;理解&#xff09; 5.3 有限域&#xff08;熟练&#xff09; 5.1 多项式环 定义&#xff1a;设F是一个域&#xff0c;称是F上的一元多项式&#xff0e; 首项&#xff1a;如果an≠0&#xff0c;则称 a…

el-dialog给弹框标题后加图标,鼠标悬停显示详细内容

效果&#xff1a; 代码&#xff1a; <div slot"title" class"el-dialog__title">标题<el-tooltip effect"dark" placement"right"><div slot"content">鼠标悬停显示</div><i class"el-icon…

队列的讲解与实现

这里写目录标题 一、队列的概念及结构二、队列的实现(使用VS2022的C语言)1.初始化、销毁2.入队、出队3.返回队头元素、返回队尾元素、判空、返回有效元素个数 三、完整 Queue.c 源代码 一、队列的概念及结构 队列&#xff1a;只允许在一端进行插入数据操作&#xff0c;在另一端…

手机相册的排列方式探讨

不论你是不是程序员&#xff0c;你一定留意过一个问题&#xff1a;相册 App 基本都将图片裁剪成了居中的 1:1 正方形。那么手机相册 App&#xff0c;为什么要将图片切割成 1:1 正方形&#xff0c;然后以网格排列&#xff1f;是行业标准吗&#xff1f; 自适应图片宽度的图库&a…

vr样板房实景漫游展示制作解决了地产商难题

家具和软装销售中&#xff0c;如何直观展示产品优势一直是老板们的难题。口头描述往往难以让客户真正感受到产品的独特之处&#xff0c;这不仅影响了销售效果&#xff0c;也增加了沟通的难度。但现在&#xff0c;我们有了全新的解决方案——样板房VR全景编辑软件! 样板房VR全景…

SpringMVC:消息转换器

1. HttpMessageConvertor 简介 HttpMessageConverter是Spring MVC中非常重要的一个接口。翻译为&#xff1a;HTTP消息转换器。该接口下提供了很多实现类&#xff0c;不同的实现类有不同的转换方式。 转换器 如上图所示&#xff1a;HttpMessageConverter接口的可以将请求协议转…

数据结构之ArrayList与顺序表(上)

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a;数据结构&#xff08;Java版&#xff09; 顺序表的学习&#xff0c;点我 上面这篇博文是关于顺序表的基础知识&#xff0c;以及顺序表的实现。…

美团面试:百亿级分片,如何设计基因算法?

尼恩说在前面 在40岁老架构师 尼恩的读者交流群(50)中&#xff0c;最近有小伙伴拿到了一线互联网企业如得物、阿里、滴滴、极兔、有赞、希音、百度、网易、美团的面试资格&#xff0c;遇到很多很重要的架构类/设计类的场景题&#xff1a; 1.说说分库分表的基因算法&#xff1f…

【Linux】深入解析动静态库:原理、制作、使用与动态链接机制

文章目录 前言&#xff1a;1. 什么是动静态库2. 动静态库的制作和使用3. 动态库的查找问题4. 理解动态库的加载4.1. 站在系统的角度理解4.2. 编址、可执行程序4.3. 动态库动态链接和加载问题 总结&#xff1a; 前言&#xff1a; 在软件开发中&#xff0c;动静态库是两种重要的…

Netty中的ByteBuf使用介绍

ByteBuf有三类&#xff1a; 堆缓存区&#xff1a;JVM堆内存分配直接缓冲区&#xff1a;有计算机内存分配&#xff0c;JVM只是保留分配内存的地址信息&#xff0c;相对于堆内存方式较为昂贵&#xff1b;复合缓冲区&#xff1a;复合缓冲区CompositeByteBuf&#xff0c;它为多个B…

6月26~28日,2024北京国际消防展即将开幕!

随着社会的快速发展&#xff0c;消防安全日益受到广大民众的高度关注。为了进一步推动消防科技的创新与发展&#xff0c;提升全民消防安全意识&#xff0c;2024年北京消防展将于6月26日在北京国家会议中心盛大开展。目前:观众预登记已全面启动&#xff0c;广大市民和业界人士可…

Skins

本主题解释如何将DevExpress主题/皮肤应用到应用程序中&#xff0c;如何允许用户在运行时在主题之间切换&#xff0c;如何自定义现有皮肤或创建自己的皮肤&#xff0c;等等。 WinForms订阅包括许多基本控件&#xff1a;按钮、复选框、表单、消息框、对话框、对话框等。 我们实现…

python面向过程与初始面向对象编程

让我们穿越到《龙珠》世界&#xff0c;一起揭开 面向对象编程 的神秘面纱吧。 面向过程编程与面向对象编程 天下第一武道会 选手登记 第 22 届天下第一武道会即将召开&#xff0c;各路武术高手齐聚一堂&#xff0c;其中最受瞩目的&#xff0c;当属卡卡罗特&#xff08;孙悟…