【学术论文投稿】JavaScript 前端开发:从入门到精通的奇幻之旅

【中文核刊&普刊投稿通道】2024年体育科技与运动表现分析国际学术会议(ICSTPA 2024)_艾思科蓝_学术一站式服务平台

更多学术会议论文投稿请看:https://ais.cn/u/nuyAF3 

目录

一、引言

二、JavaScript 基础

(一)变量与数据类型

(二)运算符

(三)控制结构

三、函数

(一)函数定义与调用

(二)函数作用域

(三)闭包

四、DOM 操作

(一)DOM 简介

(二)获取元素

(三)修改元素属性

(四)添加和删除元素

五、事件处理

(一)事件简介

(二)添加事件处理程序

(三)常见事件类型


 

一、引言

在当今的互联网世界中,前端开发扮演着至关重要的角色。而 JavaScript 无疑是前端开发领域的核心技术之一。它就像一把神奇的钥匙,打开了创建交互式网页的大门。无论是炫酷的动画效果、动态的数据更新,还是复杂的用户交互逻辑,JavaScript 都能轻松应对。从简单的网页表单验证到构建大型的单页面应用程序(SPA),JavaScript 的应用场景无处不在。在这篇博客中,我们将深入探讨 JavaScript 前端开发的各个方面,带领大家踏上从入门到精通的精彩旅程。

二、JavaScript 基础

(一)变量与数据类型

  1. 变量声明
    在 JavaScript 中,我们可以使用 varlet 和 const 来声明变量。var 是早期的变量声明方式,它存在变量提升的问题。例如:
    console.log(a); // 输出 undefined
    var a = 5;

    let 和 const 是 ES6 引入的新方式。let 声明的变量不存在变量提升,且不允许在相同作用域内重复声明。const 用于声明常量,一旦赋值就不能再修改。

    console.log(b); // 报错:b is not defined
    let b = 10;
    const c = 20;
    c = 30; // 报错:Assignment to constant variable.
  2. 数据类型
    JavaScript 有多种数据类型,包括基本数据类型和复杂数据类型。基本数据类型有:
    • Number:用于表示数字,包括整数和浮点数。例如:let num = 42; 或 let floatNum = 3.14;
    • String:用于表示文本。可以使用单引号或双引号来创建字符串。例如:let str = 'Hello, JavaScript!'; 或 let anotherStr = "This is also a string."
    • Boolean:只有两个值 true 和 false,用于表示逻辑值。例如:let isTrue = true;
    • Null:表示一个空值。例如:let emptyValue = null;
    • Undefined:当一个变量声明但未赋值时,其值为 undefined。例如:let undef; console.log(undef); // 输出 undefined
      复杂数据类型主要有:
    • Object:这是 JavaScript 中最复杂的数据类型。对象可以包含多个属性和方法。例如:
      let person = {name: 'John',age: 30,sayHello: function() {console.log('Hello!');}
      };
    • Array:用于存储一组有序的值。例如:let fruits = ['apple', 'banana', 'cherry'];

(二)运算符

  1. 算术运算符
    JavaScript 中的算术运算符包括加(+)、减(-)、乘(*)、除(/)和取模(%)。需要注意的是,加法运算符在处理字符串时会进行字符串拼接。例如:
    let num1 = 5;
    let num2 = 3;
    console.log(num1 + num2); // 8
    let str1 = 'Hello, ';
    let str2 = 'world!';
    console.log(str1 + str2); // Hello, world!
  2. 比较运算符
    比较运算符用于比较两个值,返回一个布尔值。包括等于(==)、不等于(!=)、全等(===)、不全等(!==)、大于(>)、小于(<)、大于等于(>=)和小于等于(<=)。全等运算符会比较值和数据类型,而等于运算符只比较值。例如:
    console.log(5 == '5'); // true
    console.log(5 === '5'); // false
  3. 逻辑运算符
    逻辑运算符包括与(&&)、或(||)和非(!)。&& 运算符当两个操作数都为真时返回真,|| 运算符当至少一个操作数为真时返回真,! 运算符用于取反。例如:
    let a = true;
    let b = false;
    console.log(a && b); // false
    console.log(a || b); // true
    console.log(!a); // false

(三)控制结构

  1. 条件语句(if - else)
    if - else 语句用于根据条件执行不同的代码块。例如:
    let score = 80;
    if (score >= 90) {console.log('优秀');
    } else if (score >= 80) {console.log('良好');
    } else if (score >= 60) {console.log('及格');
    } else {console.log('不及格');
    }
  2. 循环语句(for、while、do - while)
    • for 循环:常用于已知循环次数的情况。例如:
      for (let i = 0; i < 5; i++) {console.log(i);
      }

    • 循环语句(for、while、do - while)
      • for 循环:常用于已知循环次数的情况。例如:
        for (let i = 0; i < 5; i++) {console.log(i);
        }
      • while 循环:在条件为真时持续执行代码块。例如:
        let j = 0;
        while (j < 3) {console.log(j);j++;
        }
      • do - while 循环:与 while 循环类似,但会先执行一次代码块再检查条件。例如:
        let k = 0;
        do {console.log(k);k++;
        } while (k < 2);

三、函数

(一)函数定义与调用

函数是 JavaScript 中的重要组成部分,可以将一段可重复使用的代码封装起来。函数可以使用函数声明或函数表达式来定义。

  1. 函数声明
    function add(num1, num2) {return num1 + num2;
    }
    console.log(add(3, 5)); // 8
  2. 函数表达式
    let multiply = function(num1, num2) {return num1 * num2;
    };
    console.log(multiply(2, 4)); // 8

    函数可以有参数和返回值。参数是函数接收外部传入的值,返回值是函数执行后返回的结果。

(二)函数作用域

JavaScript 中的函数有自己的作用域。在函数内部定义的变量在函数外部是不可访问的,而在函数外部定义的变量在函数内部如果没有同名变量则可以访问。例如:

let globalVar = 10;
function testScope() {let localVar = 20;console.log(globalVar); // 10
}
testScope();
console.log(localVar); // 报错:localVar is not defined

(三)闭包

闭包是 JavaScript 中一个比较高级但非常重要的概念。它允许函数访问其定义时所在的词法作用域,即使在函数在其词法作用域之外被执行时。例如:

function outerFunction() {let count = 0;return function() {count++;console.log(count);};
}
let inner = outerFunction();
inner(); // 1
inner(); // 2

在这个例子中,inner 函数形成了一个闭包,它可以访问并修改 outerFunction 中定义的 count 变量。

四、DOM 操作

(一)DOM 简介

DOM(Document Object Model)是文档对象模型,它将 HTML 文档表示为一个树形结构。在 JavaScript 中,我们可以通过 DOM API 来操作 HTML 元素,如获取元素、修改元素属性、添加或删除元素等。

(二)获取元素

  1. 通过 ID 获取元素
    可以使用 document.getElementById 方法来获取具有特定 ID 的元素。例如:
    <!DOCTYPE html>
    <html>
    <body><div id="myDiv">这是一个 div 元素</div><script>let myDiv = document.getElementById('myDiv');console.log(myDiv.innerHTML); // 这是一个 div 元素
    </script>
    </body>
    </html>
  2. 通过标签名获取元素
    使用 document.getElementsByTagName 方法可以获取指定标签名的所有元素。例如:
    <!DOCTYPE html>
    <html>
    <body><p>段落 1</p>
    <p>段落 2</p><script>let paragraphs = document.getElementsByTagName('p');for (let i = 0; i < paragraphs.length; i++) {console.log(paragraphs[i].innerHTML);}
    </script>
    </body>
    </html>
  3. 通过类名获取元素
    document.getElementsByClassName 方法用于获取具有特定类名的所有元素。例如:
    <!DOCTYPE html>
    <html>
    <body><div class="myClass">类名为 myClass 的 div 1</div>
    <div class="myClass">类名为 myClass 的 div 2</div><script>let myClassElements = document.getElementsByClassName('myClass');for (let i = 0; i < myClassElements.length; i++) {console.log(myClassElements[i].innerHTML);}
    </script>
    </body>
    </html>

(三)修改元素属性

可以通过 JavaScript 来修改元素的各种属性,如修改元素的样式、内容等。

  1. 修改样式
    可以直接修改元素的 style 属性来改变其样式。例如:
    <!DOCTYPE html>
    <html>
    <body><div id="myDiv" style="width: 100px; height: 100px; background-color: red;">原始 div</div><script>let myDiv = document.getElementById('myDiv');myDiv.style.backgroundColor = 'blue';myDiv.style.width = '200px';
    </script>
    </body>
    </html>
  2. 修改内容
    可以使用 innerHTML 属性来修改元素的内容。例如:
    <!DOCTYPE html>
    <html>
    <body><div id="myDiv">原始内容</div><script>let myDiv = document.getElementById('myDiv');myDiv.innerHTML = '新内容';
    </script>
    </body>
    </html>

(四)添加和删除元素

  1. 添加元素
    可以使用 document.createElement 创建新元素,然后使用 appendChild 方法将其添加到父元素中。例如:
    <!DOCTYPE html>
    <html>
    <body><div id="parentDiv"></div><script>let parentDiv = document.getElementById('parentDiv');let newDiv = document.createElement('div');newDiv.innerHTML = '新创建的 div';parentDiv.appendChild(newDiv);
    </script>
    </body>
    </html>
  2. 删除元素
    可以使用 parentNode.removeChild 方法来删除一个元素。例如:
    <!DOCTYPE html>
    <html>
    <body><div id="parentDiv"><div id="childDiv">要删除的 div</div>
    </div><script>let childDiv = document.getElementById('childDiv');let parentDiv = document.getElementById('parentDiv');parentDiv.removeChild(childDiv);
    </script>
    </body>
    </html>

五、事件处理

(一)事件简介

事件是用户与网页交互时产生的动作,如点击、鼠标移动、键盘按键等。JavaScript 可以通过事件处理程序来响应这些事件。

(二)添加事件处理程序

  1. 内联方式
    可以在 HTML 元素的属性中直接添加事件处理程序。例如:
    <button onclick="alert('你点击了按钮');">点击我</button>

    不过这种方式将 JavaScript 代码与 HTML 代码混合,不利于维护,一般不推荐使用。
    2. 脚本方式
    可以使用 JavaScript 在脚本中为元素添加事件处理程序。例如:

    <!DOCTYPE html>
    <html>
    <body><button id="myButton">点击我</button><script>let myButton = document.getElementById('myButton');myButton.addEventListener('click', function() {console.log('按钮被点击了');});
    </script>
    </body>
    </html>

    这里使用了 addEventListener 方法,它可以为元素添加多个相同类型的事件处理程序,并且可以更好地控制事件的传播。

(三)常见事件类型

  1. 鼠标事件
    常见的鼠标事件包括 click(点击)、mouseover(鼠标移到元素上)、mouseout(鼠标移出元素)等。例如:
    <!DOCTYPE html>
    <html>
    <body><div id="myDiv" style="width: 100px; height: 100px; background-color: red;">鼠标悬停测试</div><script>let myDiv = document.getElementById('myDiv');myDiv.addEventListener('mouseover', function() {this.style.backgroundColor = 'blue';});myDiv.addEventListener('mouseout', function() {this.style.backgroundColor = 'red';});
    </script>
    </body>
    </html>
  2. 键盘事件
    键盘事件有 keydown(键盘按键按下)、keyup(键盘按键松开)等。例如:
    <!DOCTYPE html>
    <html>
    <body><input type="text" id="myInput"><script>let myInput = document.getElementById('myInput');myInput.addEventListener('keydown', function(event) {console.log('按下的键码:', event.keyCode);});
    </script>
    </body>
    </html>
  3. 表单事件
    对于表单元素,有 submit(表单提交)、change(表单元素值改变)等事件。例如:
    <!DOCTYPE html>
    <html>
    <body><form id="myForm"><input type="text" id="myInput"><input type="submit" value="提交">
    </form><script>let myForm = document.getElementById('myForm');myForm.addEventListener('submit', function(event) {event.preventDefault();console.log('表单提交');});let myInput = document.getElementById('myInput');myInput.addEventListener('change', function() {console.log('输入框内容改变');});
    </script>
    </body>
    </html>

    这里在表单的 submit 事件处理程序中使用了 event.preventDefault 方法来阻止表单的默认提交行为。

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

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

相关文章

Leetcode 最长回文子串

目录 解法1&#xff1a;递归算法 解法2&#xff1a;Map取同字母位置法 解法3&#xff1a;中心扩展法 解法4&#xff1a;动态规划法 解法5: Manacher算法 示例 1&#xff1a; 输入&#xff1a;s "babad" 输出&#xff1a;"bab" 解释&#xff1a;&quo…

SpringBoot(8)-任务

目录 一、异步任务 二、定时任务 三、邮件任务 一、异步任务 使用场景&#xff1a;后端发送邮件需要时间&#xff0c;前端若响应不动会导致体验感不佳&#xff0c;一般会采用多线程的方式去处理这些任务&#xff0c;但每次都需要自己去手动编写多线程来实现 1、编写servic…

WebStorm 2022.3.2/IntelliJ IDEA 2024.3出现elementUI提示未知 HTML 标记、组件引用爆红等问题处理

WebStorm 2022.3.2/IntelliJ IDEA 2024.3出现elementUI提示未知 HTML 标记、组件引用爆红等问题处理 1. 标题识别elementUI组件爆红 这个原因是&#xff1a; 在官网说明里&#xff0c;才版本2024.1开始&#xff0c;默认启用的 Vue Language Server&#xff0c;但是在 Vue 2 项…

Odoo :免费且开源的农牧行业ERP管理系统

文 / 开源智造Odoo亚太金牌服务 引言 提供农牧企业数字化、智能化、无人化产品服务及全产业链高度协同的一体化解决方案&#xff0c;提升企业智慧种养、成本领先、产业互联的核心竞争力。 行业典型痛点 一、成本管理粗放&#xff0c;效率低、管控弱 产品研发过程缺少体系化…

【Unity踩坑】出现d3d11问题导致编辑器崩溃

升级到Unity 6&#xff0c;有时出现下面这种D3D11的问题&#xff0c;会导致编辑器崩溃。 有人总结了这个问题的解决方法&#xff0c;可以做为参考&#xff1a; Failed to present D3D11 swapchain due to device reset/removed. List of Solutions - Unity Engine - Unity Dis…

数据库基础(MySQL)

1. 数据库基础 1.1 什么是数据库 存储数据用文件就可以了&#xff0c;为什么还要弄个数据库? 文件保存数据有以下几个缺点&#xff1a; 文件的安全性问题文件不利于数据查询和管理文件不利于存储海量数据文件在程序中控制不方便 数据库存储介质&#xff1a; 磁盘内存 为…

JMeter监听器与压测监控之Grafana

Grafana 是一个开源的度量分析和可视化套件&#xff0c;通常用于监控和观察系统和应用的性能。本文将指导你如何在 Kali Linux 上使用 Docker 来部署 Grafana 性能监控平台。 前提条件 Kali Linux&#xff1a;确保你已经安装了 Kali Linux。Docker&#xff1a;确保你的系统已…

集群聊天服务器(13)redis环境安装和发布订阅命令

目录 环境安装订阅redis发布-订阅的客户端编程环境配置客户端编程 功能测试 环境安装 sudo apt-get install redis-server 先启动redis服务 /etc/init.d/redis-server start默认在6379端口上 redis是存键值对的&#xff0c;还可以存链表、数组等等复杂数据结构 而且数据是在…

linux常用指令总结(附Vim编辑器学习总结)

本文是博主对Linux中经常用到的一些指令进行的总结&#xff0c;文章也附带了Linux中经常用到的Vim编辑器的一些基本知识和使用指令&#xff0c;觉得有帮助的朋友可以点赞收藏&#xff01; 本文会持续进行更新 linux常用指令总结 $ pwd # 查看当前终端所在…

w046基于web的古典舞在线交流平台的设计与实现

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;原创团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文…

阿里云轻量应用服务器可以用在哪些场景呢

在数字化转型的浪潮中&#xff0c;中小企业面临着如何快速、高效地上云的挑战。阿里云轻量应用服务器&#xff08;SWAS&#xff09;作为一款专为中小企业设计的云服务产品&#xff0c;提供了简单易用、经济实惠的解决方案&#xff0c;助力企业轻松实现云端部署&#xff0c;赋能…

爬虫开发工具与环境搭建——使用Postman和浏览器开发者工具

第三节&#xff1a;使用Postman和浏览器开发者工具 在网络爬虫开发过程中&#xff0c;我们经常需要对HTTP请求进行测试、分析和调试。Postman和浏览器开发者工具&#xff08;特别是Network面板和Console面板&#xff09;是两种最常用的工具&#xff0c;能够帮助开发者有效地捕…

【操作系统】每日 3 题(二十九)

✍个人博客&#xff1a;https://blog.csdn.net/Newin2020?typeblog &#x1f4e3;专栏地址&#xff1a;https://blog.csdn.net/newin2020/category_12820365.html &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享操作系统面试中常见的面试题给大家~ ❤️…

JSON.stringify的应用说明

前言 JSON.stringify() 方法将 JavaScript 对象转换为字符串,在日常开发中较常用&#xff0c;但JSON.stringify其实有三个参数&#xff0c;后两个参数&#xff0c;使用较少&#xff0c;今天来介绍一下后两个参数的使用场景和示例。 语法及参数说明 JSON.stringify()&#xf…

Orcad 输出有链接属性的PDF

安装adobe pdf安装Ghostscript修改C:\Cadence\SPB_16.6\tools\capture\tclscripts\capUtils\capPdfUtil.tcl ​ 设置默认打印机为 Adobe PDF ​ 将Ghostscript的路径修改正确 打开cadence Orcad &#xff0c;accessories->candece Tcl/Tk Utilities-> Utilities->PD…

React(二)

文章目录 项目地址七、数据流7.1 子组件传递数据给父组件7.1.1 方式一:給父设置回调函数,传递给子7.1.2 方式二:直接将父的setState传递给子7.2 给props传递jsx7.2.1 方式一:直接传递组件给子类7.2.2 方式二:传递函数给子组件7.3 props类型验证7.4 props的多层传递7.5 cla…

Electron教程1-初学入门

玩转Electron Electron 是什么注意事项环境安装安装 vscode安装 git 第一个实例第二个实例第二个实例解读 总结问题解答 Electron 是什么 Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 嵌入 Chromium 和 Node.js 到 二进制的 Electron 允许您保持一个…

类和对象——拷贝构造函数,赋值运算符重载(C++)

1.拷⻉构造函数 如果⼀个构造函数的第⼀个参数是自身类类型的引用&#xff0c;且任何额外的参数都有默认值&#xff0c;则此构造函数也叫做拷贝构造函数&#xff0c;也就是说拷贝构造是⼀个特殊的构造函数。 // 拷贝构造函数//d2(d1) Date(const Date& d) {_year d._yea…

一文详细深入总结服务器选型

1. 题记&#xff1a; 服务器选型工作是项目规划检讨的一项非常重要的工作&#xff0c;本文详细深入总结服务器选型。 2. 服务器基础知识概览 2.1 服务器的定义与功能 2.1 .1 定义 服务器是一种高性能计算机&#xff0c;其设计目的是在网络中提供服务。它可以处理来自多个客…

多线程--常见锁策略--Java

目录 一、悲观锁VS乐观锁 1.悲观锁 2.乐观锁 二、重量级锁VS轻量级锁 1.重量级锁 2.轻量级锁 三、自旋锁 1.自旋锁概念 四、公平锁VS非公平锁 1.公平锁 2.非公平锁 3.注意 五、可重入锁和不可重入锁 六、读写锁 1.线程对于数据的访问方式 注意&#xff1a;以下讲…