当前位置: 首页 > article >正文

JavaScript相关内容

定义变量let 变量名 值 var const对比项varletconst作用域函数级块级块级变量提升提升且为 undefined提升但 TDZ 死区同 let重复声明允许不允许不允许重新赋值可以可以不可以声明时赋值可先声明可先声明必须赋值数据类型number 数字类型 string 字符串类型 boolean 布尔类型 undefined 变量声明未初始化 null 空对象 object 复合类型输入方式prompt(请输入 )输出方式console.log(123) // 控制台 alert(提示) // 弹窗 document.write(内容) // 写入页面查看数据类型typeof() instanceof()Object.prototype.toString.call([]) // [object Array] typeof 123 // number typeof abc // string typeof undefined // undefined typeof null // object历史bug typeof [] // object [] instanceof Array // true比较运算符 等于 全等 !不等于 大于 小于 大于等于 小于等于逻辑运算符: 字符串拼接“”条件if (条件){执行语句} if……else if……else if……else…… switchif (条件) { } else if (条件) { } else { }switch (a) { case 1: break case 2: break default: }循环for let while (条件) do ……while(条件)for (let i 0; i 10; i) { }for in 遍历对象key for of 遍历数组valuefor (let key in obj) {}for (let val of arr) {}函数函数定义函数声明function 函数名{} 箭头函数: let 函数名 {} 函数表达式const 函数名 function(){}箭头函数特点没有自己的this没有arguments不能当构造函数不能使用yieldfunction fn() {} const fn () {} const fn function() {}参数//普通参数 function sum(a, b) { return a b } //默认参数 function fn(a 1, b 2) {} //剩余参数 function fn(...args) { console.log(args) // 数组 } //类数组存储实参 function fn() { console.log(arguments) }调用函数let a fn(); console.log(a);对象创建对象方式 const 对象名 new Object(); const 对象名 {};const obj {name:value} const obj new Object()访问obj.name; obj[name];遍历for (let key in obj) {} Object.keys(obj) Object.values(obj) Object.entries(obj)数组创建空数组:let 数组名 [] let 数组名 new Array()const arr [1,2,3] const arr new Array()多维数组let 数组名 [[ ],[ ],[ ]];数组操作方法增push() // 尾部加 unshift() // 头部加 splice(i,0,val)// 中间插 在i插入val删pop() // 删尾 shift() // 删头 splice(i,n) // 删任意 从索引i开始删除n个元素 slice(begin,end)// 截取不影响原数组改splice(i,n,val……) //从i开始删除n个元素然后插入val查forEach() map() // 返回新数组 reduce() // 累计 some() // 一个满足 every() // 全部满足其他sort() // 排序 reverse() // 反转 join() // 转字符串 concat() // 合并 copywithin() // 批量复制 按照指定范围复制数组中部分内容 // 后将其插入指定索引开始位置 fill(val,i) // 填充数组 从i开始填充val事件onclick // 点击元素 onchange // HTML元素改变 onmouseover //鼠标指针移动到指定的元素上时发生 onmouseout //用户从HTML元素上移开鼠标时发生 onkeydown //按下键盘 onload //浏览器完成页面加载 button onclick/button错误try { ... //异常的抛出 } catch(e) { ... //捕捉到 try 块中的错误并执行代码来处理 } finally { ... //不论之前的 try 和 catch 是否产生异常都会执行该代码块 }表单form namemyForm methodpost 名字: input typetext namemyname input typesubmit value提交 /formfunction validateForm() { var yanz document.forms[myForm][myname].value; if (yanz null || x yanz ) { alert(名字不能为空); return false; } }面向对象class Person { constructor(name) { this.name name } say() { console.log(this.name) } static run() { console.log(static) } } class Student extends Person { constructor() { super() } }MathMath.random() Math.floor() Math.ceil() Math.round() Math.max() Math.min()Dateconst d new Date() d.getFullYear() d.getMonth() d.getDate() d.getHours() d.getMinutes() d.getSeconds()StringindexOf() split() substr() substring() replace() trim() toUpperCase() toLowerCase()回调函数setTimeout(() { // 回调 }, 1000)Promisenew Promise((resolve, reject) { setTimeout(() { resolve(ok) }) }) .then(res {}) //指定Promise状态变为fulfilled或rejected时的回调函数 .catch(err {}) //处理Promise被拒绝的情况 .finally(() {}) // 无论Promise最终状态如何都会执行静态方法Promise.all() // 等待所有Promise完成或任意一个失败 Promise.race() //返回最先完成的结果无论是成功还是失败async/await await只能在async函数内部使用await会暂停async函数的执行等待Promise完成async function fn() { const res await request() }DOM获取元素document.getElementById(id) document.querySelector(.类选择器) document.querySelectorAll(标签选择器)获取改变标签的内容或属性操作内容innerHTML // 获取修改元素内文字包含标签和样式 innerText // 获取或者修改元素内文字不包括标签和样式 textContent //操作属性className // 给标签添加属性 elem.src elem.href elem.setAttribute elem.getAttribute操作样式elem.style.color elem.classList.add() elem.classList.remove() elem.classList.toggle()操作节点document.createElement appendChild removeChild insertBefore事件const btn document.getElementById(btn); btn.onclick function () { alert(hi!); } // 1 btn.addEventListener(click,function (){ if () { } else { } }) // 2 btn.addEventListener(click, () { alert(hi); }) // 3定时器//创建定时器 setTimeout(() { }, 1000) //调用一次 setInterval(() { }, 1000) //重复调用 clearTimeout() //销毁定时器 const timed setTimeout(要执行的函数名,时间间隔,参数) clearTimeouttimed

相关文章:

JavaScript相关内容

定义变量: let 变量名 值; var const 对比项varletconst作用域函数级块级 块级 变量提升提升且为 undefined提升但 TDZ 死区同 let 重复声明允许不允许 不允许 重新赋值可以可以不可以声明时赋值可先声明 可先声明 必须赋值数据类型&…...

西门子1200PLC与施耐德变频器Modbus通讯程序:实现变频启停、设定频率、读取电压、电流...

西门子1200plc与施耐德变频器modbus通讯程序,可以控制变频启停,设定频率,读取变频器电压、电流、运行频率,博图V14版本程序。直接上干货!今天咱们聊聊西门子S7-1200 PLC和施耐德ATV系列变频器的Modbus通讯实战。这个方…...

避坑指南:ESP32C3开发板音频系统常见问题排查(I2S+ES8311实战)

ESP32C3音频开发实战:ES8311芯片配置与I2S疑难解析 当你在深夜调试ESP32C3开发板的音频系统时,突然发现扬声器发出刺耳的噪声,或是麦克风捕捉到的声音断断续续——这种场景对嵌入式音频开发者来说再熟悉不过了。立创开发板上的ES8311编解码芯…...

Oracle EBS的帐套由“4C”构成,而华为MetaERP将其发展为“6C”

Oracle EBS的帐套由“4C”构成,而华为MetaERP将其发展为“6C”。这不仅是简单增加两个要素,更是一种核算架构理念的革新:从 “一维定式” 转向 “多维解耦” ,旨在解决大型企业在全球化、多元化发展中的数据标准化、精细化管理与自…...

小米6刷机全攻略:从解锁BL到Recovery刷入

1. 解锁BootLoader前的准备工作 小米6作为一代经典机型,至今仍有大量用户在使用。刷机可以带来更流畅的系统体验、更长的续航时间,或是尝鲜第三方ROM的乐趣。但在开始之前,我们需要做好充分准备。我刷过不下20台小米6,总结出几个关…...

MATLAB里画双移线总报错?手把手教你解决MPC轨迹跟踪仿真中的参考轨迹绘制难题

MATLAB双移线绘制报错全解析:从MPC轨迹跟踪到参考轨迹精准生成 引言:当MATLAB遇上双移线 在无人驾驶和车辆控制领域,双移线测试是评估车辆动态性能和控制器跟踪能力的黄金标准。作为MPC(模型预测控制)算法的学习者&…...

langchain学习--提示词

langchain提示词学习要点提示词(Prompt)在LangChain中扮演着核心角色,直接影响模型输出的质量和准确性。以下是关键学习方向和实践方法:基础结构设计明确指令:直接说明任务要求,例如"生成一份关于气候…...

从14k+star的goview到完整解决方案:手把手教你集成dcluster实现数据可视化全流程

从14kstar的goview到完整解决方案:手把手教你集成dcluster实现数据可视化全流程 在数据驱动的时代,企业对于可视化分析的需求日益增长。开源项目goview凭借其14k的star数,已成为前端数据可视化领域的明星产品。但真正要在企业环境中落地&…...

香橙派RK3588驱动开发避坑实录:VSCode+Clangd环境搭建与‘version magic’错误解决

香橙派RK3588驱动开发避坑实录:VSCodeClangd环境搭建与‘version magic’错误解决 在嵌入式Linux驱动开发领域,香橙派RK3588凭借其强大的性能和丰富的接口资源,正成为越来越多开发者的首选平台。然而,从零开始搭建一个高效的开发…...

别再只用Simulink了!用Pixhawk飞控+UE4搭建无人机集群仿真,我踩过的坑都在这

从Simulink到PixhawkUE4:无人机集群仿真进阶实战指南 当我在实验室第一次尝试将Pixhawk飞控与UE4引擎结合搭建无人机集群仿真系统时,原以为只是简单的接口对接工作,没想到在数据同步、硬件兼容性和分布式通信上踩遍了所有可能的坑。这篇文章就…...

STM32 SysTick定时器在实时系统中的精准时间管理实践

1. SysTick定时器的核心原理与RTOS适配 SysTick作为ARM Cortex-M内核的标准配置,本质上是一个24位递减计数器。我在多个STM32项目中发现,它的设计初衷就是为操作系统提供稳定时基。与通用定时器不同,SysTick直接集成在NVIC中,这意…...

保姆级教程:用Keil5同时开发51单片机和STM32(C51+MDK环境配置)

嵌入式开发双环境实战:Keil5高效配置C51与MDK开发平台 在嵌入式开发领域,51单片机和STM32系列因其各自优势长期占据重要地位。许多工程师在日常工作中需要同时处理这两种架构的项目,频繁切换开发环境不仅降低效率,还容易导致开发…...

3个步骤掌握抖音评论数据采集:零基础用户的高效解决方案

3个步骤掌握抖音评论数据采集:零基础用户的高效解决方案 【免费下载链接】TikTokCommentScraper 项目地址: https://gitcode.com/gh_mirrors/ti/TikTokCommentScraper 在当今数据驱动的时代,高效获取用户反馈和市场洞察变得至关重要。本文介绍的…...

从Thread.sleep()到VirtualThread.unpark():Java 25虚拟线程配置全流程拆解(含JFR火焰图对比+GC日志精读)

第一章:Java 25虚拟线程演进本质与高并发架构适配定位Java 25正式将虚拟线程(Virtual Threads)从预览特性转为标准特性,标志着JVM并发模型进入轻量级调度新范式。其演进本质并非简单增加一种线程类型,而是重构了“线程…...

3种核心价值助你掌控数字记忆:WeChatMsg聊天记录管理工具全解析

3种核心价值助你掌控数字记忆:WeChatMsg聊天记录管理工具全解析 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending…...

2026毕业论文降AI指南:deepseek免费降AI指令+降AI神器测评,有效降低AI率【建议收藏】

快过年了,毕业生们日子并不好过,最近私信里哀鸿遍野。 “学姐,我明明是自己写的,为什么查重报告显示AI率80%?” “救命,用了劣质降AI工具结果语句不通,导师直接退回了……” 这几年AI领域发展…...

赛博朋克2077存档修改器:终极自定义游戏体验指南

赛博朋克2077存档修改器:终极自定义游戏体验指南 【免费下载链接】CyberpunkSaveEditor A tool to edit Cyberpunk 2077 sav.dat files 项目地址: https://gitcode.com/gh_mirrors/cy/CyberpunkSaveEditor 想要在《赛博朋克2077》的夜之城中打造属于自己的传…...

PostgreSQL 数据误删 止损操作

一、核心原理:为什么数据能恢复?​ 在 PostgreSQL 中,执行 DELETE 操作后,数据并不会立即从磁盘上物理擦除。PostgreSQL 使用多版本并发控制(MVCC)机制,删除操作仅仅是给数据行打上了一个“已删…...

【网络层-ARP地址解析协议】

网络层-ARP地址解析协议一、概念二、原理三、其他概念一、概念 1.把已知的IP地址,翻译成对应的MAC地址。 2.网络通信靠IP地址寻址(找哪台设备),局域网内实际传输数据靠MAC地址(网卡物理地址),设…...

【GUI-Agent】阶跃星辰 GUI-MCP 解读---()---执行层芭

起因是我想在搞一些操作windows进程的事情时,老是需要右键以管理员身份运行,感觉很麻烦。就研究了一下怎么提权,顺手瞄了一眼Windows下用户态权限分配,然后也是感谢《深入解析Windows操作系统》这本书给我偷令牌的灵感吧&#xff…...

储能系统双向DCDC变换器蓄电池充放电Buck与Boost模式仿真模型研究:维持直流母线电压平...

储能系统双向DCDC变换器蓄电池充放电仿真模型有buck模式 储能系统双向DCDC变换器蓄电池充放电仿真模型有buck模式和boost模式,依靠蓄电池充放电维持直流母线电压平衡双向DCDC变换器是储能系统的核心部件,它能像变形金刚一样在buck和boost模式间自由切换。…...

嵌入式单元测试框架Unity的设计与应用

1. 嵌入式开发中的单元测试困境与Unity框架的诞生在嵌入式开发领域,单元测试一直是个令人头疼的问题。想象一下,你正在为一个只有32KB Flash和4KB RAM的MCU编写代码,突然发现需要引入单元测试框架——这就像试图在火柴盒里搭建一个完整的化学…...

nuScenes 全景分割:Panoptic nuScenes 完整实现指南

nuScenes 全景分割:Panoptic nuScenes 完整实现指南 【免费下载链接】nuscenes-devkit The devkit of the nuScenes dataset. 项目地址: https://gitcode.com/gh_mirrors/nu/nuscenes-devkit Panoptic nuScenes 是 nuScenes 数据集的重要扩展,提供…...

Windows电脑突然变卡?手把手教你排查Artemis僵尸网络(附注册表修复脚本)

Windows系统异常卡顿?可能是Artemis僵尸网络在作祟 最近电脑突然变得异常缓慢,任务管理器打不开,甚至文件夹选项也消失了?这可能是Artemis僵尸网络在背后捣鬼。作为一名长期与Windows系统打交道的技术顾问,我见过太多用…...

Build-A-Large-Language-Model-CN:大语言模型训练中的常见问题与解决方案

Build-A-Large-Language-Model-CN:大语言模型训练中的常见问题与解决方案 【免费下载链接】Build-A-Large-Language-Model-CN 《Build a Large Language Model (From Scratch)》是一本深入探讨大语言模型原理与实现的电子书,适合希望深入了解 GPT 等大模…...

企业级 Agent 治理平台:公司用数字帮手的必备管家

个人用智能体这个数字帮手,自己教、自己用,出点小问题也就影响自己;但公司里用,几十上百个智能体一起跑,要是没人管,麻烦事就多了:有的智能体可能随便翻公司的敏感数据,有的学会的好…...

XOutput完整指南:如何将旧游戏手柄转换为Xbox控制器

XOutput完整指南:如何将旧游戏手柄转换为Xbox控制器 【免费下载链接】XOutput DirectInput to XInput wrapper 项目地址: https://gitcode.com/gh_mirrors/xo/XOutput 你是否拥有一些老旧的游戏手柄、方向盘或摇杆,却发现它们无法在现代游戏中正常…...

别再只用‘auto’模式了!深入Halcon条码识别参数:手把手教你调优barcode_width_min与扫描线提升识别率

突破Halcon条码识别瓶颈:从参数调优到工业级精准解码实战 在工业自动化与物流分拣系统中,条码识别作为数据采集的核心环节,其准确率直接关系到整个生产线的运行效率。许多工程师在使用Halcon进行条码识别时,往往止步于默认的"…...

【计算机网络八股】【欧弟求职】TCP相关

TCP 必须能讲清: 三次握手 / 四次挥手(状态流转)拥塞控制: slow startcongestion avoidancefast retransmit / fast recovery 滑动窗口重传机制(RTO / dup ack)TIME_WAIT 为什么存在高并发下 TIME_WAIT 堆积…...

通俗秒懂:储能控制器在电网调频中的关键作用与实现原理

1. 电网调频的"急救科"与"内科":为什么需要储能控制器? 想象一下电网就像人体的血液循环系统。频率稳定相当于血压稳定,一旦出现波动,轻则头晕目眩(电能质量下降),重则危及…...