news 2026/4/23 2:50:25

JS核心语法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JS核心语法
特性varletconst
块级作用域❌(函数级作用域)
变量提升✅(可先使用后声明)❌(暂时性死区)❌(暂时性死区)
重复声明
重新赋值❌(声明时必须赋值)
// var 问题:无块级作用域 if (true) { var a = 10; } console.log(a); // 10(全局可见,不合理) // let 解决块级作用域 if (true) { let b = 20; } console.log(b); // 报错:b is not defined // const 常量(不可修改引用) const PI = 3.14159; PI = 3; // 报错:Assignment to constant variable const obj = { name: '张三' }; obj.name = '李四'; // 允许(仅禁止修改引用,对象内容可改)
console.log(num); // undefined(变量提升,声明了但未赋值) var num = 10; // let/const 无变量提升 console.log(num2); // 报错:Cannot access 'num2' before initialization let num2 = 20;

三、数据类型

JS 是弱类型语言(声明变量时无需指定类型,赋值后类型可变),分为两大类:

3.1 原始类型(值类型)

存储具体值,占用空间小,赋值时拷贝值。

  • string:字符串(单引号 / 双引号 / 反引号包裹)
  • number:数值(整数、小数、NaN、Infinity)
  • boolean:布尔值(true/false)
  • undefined:声明变量未赋值时的默认值
  • null:表示 “空”(手动赋值,类型为 object,历史遗留问题)
  • symbol(ES6):唯一值(用于对象唯一属性名)
  • bigint(ES11):大整数(解决 Number 最大值2^53-1限制)
let str = 'Hello JS'; // string let num = 100; // number let bool = true; // boolean let un = undefined; // undefined let nu = null; // null let sym = Symbol('id'); // symbol let big = 9999999999999999999999999999n; // bigint

3.2 引用类型

存储内存地址,占用空间大,赋值时拷贝地址(多个变量指向同一内存)。

  • object:对象(普通对象、数组、正则、日期等)
  • function:函数(特殊的对象)
// 普通对象 let user = { name: '张三', age: 20 }; // 数组(特殊对象) let arr = [1, 2, 3]; // 函数(特殊对象) let fn = function() {};

3.4 类型转换

3.4.1 隐式转换(JS 自动触发,易踩坑)
  • 转布尔:0''undefinednullNaNfalse,其余为true
  • 转数字:字符串转数字('123' → 123'abc' → NaN),布尔转数字(true → 1false → 0)。
  • 转字符串:数字 / 布尔转字符串(123 → '123'true → 'true')。
3.4.2 显式转换(手动控制,推荐)
// 转数字 Number('123'); // 123 parseInt('123abc'); // 123(取整) parseFloat('123.45abc'); // 123.45 // 转字符串 String(123); // '123' (123).toString(); // '123' // 转布尔 Boolean(0); // false Boolean(''); // false Boolean('abc'); // true

逻辑运算符

用于条件判断,返回最终的真值 / 假值。

运算符说明示例短路规则
&&逻辑与true && false → false左假则返回左,左真返回右
``逻辑或`truefalse → true`左真则返回左,左假返回右
!逻辑非!true → false取反
// && 短路:左假返回左 console.log(false && 123); // false console.log(1 && 2 && 3); // 3(全部为真,返回最后一个) // || 短路:左真返回左 console.log(123 || false); // 123 console.log(0 || '' || 'abc'); // 'abc'(全部为假,返回最后一个) // 实用场景:设置默认值 let userName = ''; let name = userName || '游客'; // name → '游客'

三元运算符(条件运算符)

语法:条件 ? 表达式1 : 表达式2(简化 if-else)

let age = 18; let result = age >= 18 ? '成年' : '未成年'; console.log(result); // '成年' // 嵌套三元(不推荐多层,可读性差) let score = 85; let grade = score >= 90 ? 'A' : score >= 80 ? 'B' : 'C';
do-while 循环

语法:do { 循环体 } while (条件)(先执行一次,再判断条件)

let i = 0; do { console.log(i); i++; } while (i < 5);
增强循环(ES6+)

for-in:遍历对象的可枚举属性(不推荐遍历数组,会遍历原型链)

let obj = { name: '张三', age: 20 }; for (let key in obj) { console.log(key, obj[key]); // name 张三, age 20 }

for-of:遍历可迭代对象(数组、字符串、Map/Set 等),返回值而非索引

let arr = ['a', 'b', 'c']; for (let val of arr) { console.log(val); // a,b,c }
循环控制
  • break:跳出当前循环(终止循环)。
  • continue:跳过当前轮循环,进入下一轮。
    // break 示例:找到第一个偶数就停止 for (let i = 1; i < 10; i++) { if (i % 2 === 0) { console.log('第一个偶数:', i); // 2 break; } } // continue 示例:只打印奇数 for (let i = 1; i < 10; i++) { if (i % 2 === 0) { continue; } console.log(i); // 1,3,5,7,9 }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 14:46:15

分公司组织架构图在线设计 总部分支管理模板

良功绘图网站 (https://www.lghuitu.com ) 在企业规模化发展的进程中&#xff0c;分公司的设立成为拓展市场、优化资源配置的重要举措。而总部分支之间的高效协同&#xff0c;离不开清晰、科学的组织架构作为支撑。分公司组织架构图作为直观呈现管理层级、部门设置、权责划分的…

作者头像 李华
网站建设 2026/4/22 16:21:03

KD-Tree的查询原理

好的&#xff0c;让我详细解释KD-Tree的查询原理&#xff0c;以及为什么它能将时间复杂度从O(n)降到O(log n)。 KD-Tree的基本结构 KD-Tree&#xff08;k-dimensional tree&#xff09;是一种用于多维空间的数据结构&#xff0c;特别适合范围搜索和最近邻搜索。 构建过程示例…

作者头像 李华
网站建设 2026/4/22 16:21:30

基于Mask R-CNN的道路路面损伤自动检测与分类研究

1. 基于Mask R-CNN的道路路面损伤自动检测与分类研究 1.1. 引言 随着城市化进程的加速&#xff0c;道路基础设施的维护变得越来越重要。传统的人工检测方法效率低下、成本高昂&#xff0c;且存在安全隐患。&#x1f6a7; 近年来&#xff0c;计算机视觉技术的快速发展为道路路…

作者头像 李华
网站建设 2026/4/22 16:20:27

最近在研究高速列车的主动悬挂系统,发现H无穷控制策略在这个领域挺有意思的。今天就来聊聊基于H无穷控制策略的横摆半车9自由度高速列车主动悬挂

基于H无穷控制策略的横摆半车9自由度高速列车主动悬挂首先&#xff0c;我们得明白什么是H无穷控制。简单来说&#xff0c;H无穷控制是一种鲁棒控制方法&#xff0c;能够在系统存在不确定性和外部干扰的情况下&#xff0c;保证系统的稳定性和性能。对于高速列车这种复杂系统&…

作者头像 李华
网站建设 2026/4/22 9:07:50

Ubuntu硬盘空间不够?一文带你理清过程的根分区无损扩容实战指南

复杂分区布局下的 Ubuntu 根目录无损扩容实践&#xff1a;从引导参数调试到扇区移位 摘要 本文详细记录了在一块 1TB NVMe 固态硬盘&#xff08;WD_BLACK SN770&#xff09;上&#xff0c;解决 Ubuntu 根分区&#xff08;/&#xff09;空间不足问题的全过程。本次扩容的特殊性在…

作者头像 李华
网站建设 2026/4/18 11:54:40

想让你的标书不废标应该这样做

1、检查项目编号与名称:投标文件整篇项目编号与名称是否正确。2、检查投标人名称:投标人名称与营业执照、资质证书、安全生产许可证、银行资信证明等证明证书是否一致。3、检查投标文件的排版:文本格式、字体、行数、图片是否模糊或歪斜&#xff0c;这些是否按照招标文件的要求…

作者头像 李华