js进阶语法详解

文章目录

  • js进阶语法详解
    • 一、引言
    • 二、闭包与作用域
      • 1、闭包
        • 1.1、示例代码
      • 2、作用域
        • 2.1、示例代码
    • 三、this关键字与函数调用
      • 1、this的指向
        • 1.1、示例代码
      • 2、apply和call方法
        • 2.1、示例代码
    • 四、异步编程
      • 1、Promise
        • 1.1、示例代码
    • 五、JS的面向对象封装
      • 1、封装的概念
        • 1.1、构造函数和原型链
      • 2、ES6类和模块化封装
        • 2.1、使用`class`定义类
      • 3、私有属性和方法
        • 3.1、模拟私有属性
      • 4、封装的好处
    • 六、总结

js进阶语法详解

在这里插入图片描述

一、引言

JavaScript(简称“JS”)是一种轻量级的解释型或编译型的编程语言。随着Web技术的发展,JS已经成为前端开发中不可或缺的一部分。对于想要进阶的JS开发者来说,深入了解JS的高级语法是十分必要的。本文将详细介绍JS中的一些进阶语法,并提供代码示例以供参考。

二、闭包与作用域

1、闭包

闭包是一个非常重要的JS进阶概念,它指的是一个函数和其周围的状态(词法环境)的组合。闭包可以用来创建私有变量和封装函数。

1.1、示例代码
function outerFunction() {var outerVar = "I am outer";return function innerFunction() {console.log(outerVar);};
}var inner = outerFunction();
inner(); // 输出 "I am outer"

2、作用域

JS的作用域决定了变量和函数的可见性。理解作用域对于编写清晰和可维护的代码至关重要。

2.1、示例代码
var scopeVar = "I am global";function scopeTest() {var scopeVar = "I am local";console.log(scopeVar); // 输出 "I am local"
}scopeTest();
console.log(scopeVar); // 输出 "I am global"

三、this关键字与函数调用

1、this的指向

this关键字在函数中的指向取决于函数的调用方式。理解this的指向对于对象方法和事件处理函数尤其重要。

1.1、示例代码
function showThis() {console.log(this);
}showThis(); // 输出全局对象(在浏览器中是window)var obj = {showThis: showThis
};obj.showThis(); // 输出obj对象

2、apply和call方法

applycall方法可以用来调用函数,同时指定this的值和参数列表。

2.1、示例代码
function add(a, b) {return a + b;
}var result = add.apply(null, [1, 2]); // 输出 3
var result = add.call(null, 1, 2); // 输出 3

四、异步编程

1、Promise

Promise是处理异步操作的一种方式,它代表了一个异步操作的最终完成(或失败)及其结果值。

1.1、示例代码
var promise = new Promise(function(resolve, reject) {setTimeout(function() {resolve("Resolved!");}, 1000);
});promise.then(function(value) {console.log(value); // 输出 "Resolved!"
});

五、JS的面向对象封装

面向对象编程(OOP)是一种编程范式,它将现实世界中的实体抽象为对象,并通过类和对象来模拟现实世界中的行为和属性。在JavaScript中,面向对象封装是OOP的核心概念之一,它允许我们将数据(属性)和行为(方法)封装在一起,并对外隐藏实现的细节。

1、封装的概念

封装是OOP的一个关键概念,它意味着将对象的状态(属性)和行为(方法)结合在一起,并对外隐藏对象的内部状态和实现细节。在JavaScript中,封装可以通过构造函数和原型链来实现。

1.1、构造函数和原型链

在ES6之前,JavaScript主要通过构造函数和原型链来实现面向对象的封装。构造函数用于创建对象,而原型链则用于继承和共享方法。

function Person(name, age) {this.name = name;this.age = age;
}Person.prototype.greet = function() {console.log('Hello, my name is ' + this.name + ' and I am ' + this.age + ' years old.');
};const person1 = new Person('Ning', 25);
person1.greet(); // 输出:Hello, my name is Ning and I am 25 years old.

2、ES6类和模块化封装

ES6引入了class关键字,提供了一种更接近传统面向对象语言的封装方式。通过class,我们可以更清晰地定义对象的属性和方法。

2.1、使用class定义类
class Person {constructor(name, age) {this.name = name;this.age = age;}greet() {console.log(`Hello, my name is ${this.name} and I am ${this.age} years old.`);}
}const person2 = new Person('Kimi', 25);
person2.greet(); // 输出:Hello, my name is Kimi and I am 25 years old.

3、私有属性和方法

JavaScript中没有真正的私有属性和方法,但我们可以通过一些约定来模拟私有属性,比如使用下划线前缀或者闭合函数来限制属性的访问。

3.1、模拟私有属性
class Person {#name;#age;constructor(name, age) {this.#name = name;this.#age = age;}greet() {console.log(`Hello, my name is ${this.#name} and I am ${this.#age} years old.`);}
}const person3 = new Person('Kimi', 25);
// person3.#name; // SyntaxError: Private field '#name' must be declared in an enclosing class
person3.greet(); // 输出:Hello, my name is Kimi and I am 25 years old.

4、封装的好处

封装提供了以下几个好处:

  • 数据隐藏:通过限制对内部数据的直接访问,封装保护了对象的完整性。
  • 接口简化:封装隐藏了复杂的内部实现,只暴露必要的接口给外部使用。
  • 代码重用:封装使得对象可以在不同的程序和上下文中重用,而不需要关心内部的具体实现。

通过封装,JavaScript开发者可以创建更加模块化和可维护的代码,同时提高代码的可读性和可重用性。

六、总结

JS的进阶语法是每个前端开发者必须掌握的技能。通过理解闭包、作用域、this关键字以及异步编程,你可以编写出更加强大和灵活的JS代码。希望本文能够帮助你深入理解这些概念,并在你的项目中得到应用。


版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

  • JavaScript 进阶知识 - 高级篇
  • Web前端:JavaScript最强总结 附详细代码 (带常用案例!)

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

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

相关文章

Qt WORD/PDF(一)使用 QtPdfium库实现 PDF 预览

文章目录 一、简介二、下载 QtPdfium三、加载 QtPdfium 动态库四、Demo 使用 关于QT Widget 其它文章请点击这里: QT Widget 国际站点 GitHub: https://github.com/chenchuhan 国内站点 Gitee : https://gitee.com/chuck_chee 姊妹篇: Qt WORD/PDF&#x…

.Net WebAPI(一)

文章目录 项目地址一、WebAPI基础1. 项目初始化1.1 创建简单的API1.1.1 get请求1.1.2 post请求1.1.3 put请求1.1.4 Delete请求 1.2 webapi的流程 2.Controllers2.1 创建一个shirts的Controller 3. Routing3.1 使用和创建MapControllers3.2 使用Routing的模板语言 4. Mould Bind…

备战美赛!2025美赛数学建模C题模拟预测!用于大家练手模拟!

完整的思路代码模型见文末 2025 美赛数学建模 C 题 模拟题:城市交通拥堵指数的预测与管理策略 背景 随着全球城市化进程的加快,交通拥堵问题成为城市发展的重要挑战之一。交通拥堵不仅影响居民出行效率,还增加了能源消耗和碳排放。近年来&…

Java操作Redis-Jedis

介绍 前面我们讲解了Redis的常用命令,这些命令是我们操作Redis的基础,那么我们在 java程序中应该如何操作Redis呢?这就需要使用Redis的Java客户端,就如同我们使 用JDBC操作MySQL数据库一样。 Redis 的 Java 客户端很多&#xff0…

英语-日常笔记-2

You can refer to the previous code logic.你可以参考以前的代码逻辑 只是刚开始做 just started doing it/just began to do it 由你自己决定 it’s up to you /it depends on you 这一版需求不急 this demand version is not urgent there is no rush for this requireme…

Vue3 + Element-Plus + vue-draggable-plus 实现图片拖拽排序和图片上传到阿里云 OSS 父组件实现真正上传(最新保姆级)

Vue3 Element-Plus vue-draggable-plus 实现图片拖拽排序和图片上传到阿里云 OSS(最新保姆级)父组件实现真正上传 1、效果展示2、UploadImage.vue 组件封装3、相关请求封装4、SwiperConfig.vue 调用组件5、后端接口 1、效果展示 如果没有安装插件&…

将 Ubuntu 22.04 LTS 升级到 24.04 LTS

Ubuntu 24.04 LTS 将支持 Ubuntu 桌面、Ubuntu 服务器和 Ubuntu Core 5 年,直到 2029 年 4 月。 本文将介绍如何将当前 Ubuntu 22.04 系统升级到最新 Ubuntu 24.04 LTS版本。 备份个人数据 以防万一,把系统中的重要数据自己备份一下~ 安装配置SSH访问…

宝塔SSL证书申请失败,报错:申请SSL证书错误 module ‘OpenSSL.crypto‘ has no attribute ‘sign‘(已解决)

刚安装宝塔申请SSL就报错:申请SSL证书错误 module OpenSSL.crypto has no attribute sign 面板、插件版本:9.2.0 系统版本:Alibaba Cloud Linux 3.2104 LTS 问题:申请SSL证书错误 module OpenSSL.crypto has no attribute sign…

clickhouse优化记录

一、注重使用分区键来加快查询 在大数据量的情况下,如果查询语句中,可以使用分区键来进行查询,可以极大缩小数据的查询范围,加快查询速度。 二、使用order by的列,适用最左前缀匹配原则 比如表的结构是 order by(id…

【人工智能】从TF-IDF到BERT:Python实现文本分类的全面指南

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 文本分类是自然语言处理领域中的核心任务之一,被广泛应用于情感分析、垃圾邮件检测等场景。本文章通过完整的Python代码示例,从传统的TF-…

<mutex>注释 12:重新思考与猜测、补充锁的睡眠与唤醒机制,结合 linux0.11 操作系统代码的辅助(下)

(60)继续分析,为什么 timed_mutex 可以拥有准时的等待时间: 逐步测试: 以及: 以及: 以及: 上面的例子里之所以这么编写。无论 timed_mutex 里的定时等待函数,还是 条件…

CentOS7源码编译安装nginx+php+mysql

1.安装nginx 安装依赖 yum -y install gcc gcc-c wget automake autoconf libtool libxml2-devel libxslt-devel perl-devel perl-ExtUtils-Embed pcre-devel openssl openssl-devel 创建一个不能登录的nginx运行用户 groupadd www-data useradd -s /sbin/nologin -g www-d…

关于VS项目中添加第三方库出现error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int 错误的解决方法

最近由于在已有项目中进行一些矩阵运行与线性代数计算&#xff0c;因此添加了第三方开源库Eigen&#xff0c;由于Eigen相关的代码是由同事编写的。将其移植到现有项目中时在包含Eigen的头文件后,项目就出现了68个相关错误&#xff0c;如标题所示的错误。 #include <Eigen/D…

深度学习(15)从头搭建模型到训练、预测示例总结

深度学习&#xff08;15&#xff09;从头搭建模型到训练、预测示例总结 总结一下从头搭建模型的流程再次熟悉一下模型结构与训练、推理流程本文主要介绍通过 Pytorch 实现模型结构实现 1.价格预测 要搭建一个深度学习网络模型用于价格预测&#xff0c;首先需要明确问题的类型…

【MySQL】InnoDB引擎中的Compact行格式

目录 1、背景2、数据示例3、Compact解释【1】组成【2】头部信息【3】隐藏列【4】数据列 4、总结 1、背景 mysql中数据存储是存储引擎干的事&#xff0c;InnoDB存储引擎以页为单位存储数据&#xff0c;每个页的大小为16KB&#xff0c;平时我们操作数据库都是以行为单位进行增删…

Kylin麒麟操作系统 | 网络链路聚合配置(team和bond)

目录 一、理论储备1. 链路聚合 二、任务实施1. team模式2. bond模式 一、理论储备 1. 链路聚合 链路聚合是指将多个物理端口捆绑在一起&#xff0c;形成一个逻辑端口&#xff0c;以实现出/入流量在各成员端口中的负载分担。链路聚合在增加链路带宽、实现链路传输弹性和冗余等…

探索 AIGC:从内容生产到智能创意的新时代

近年来&#xff0c;人工智能&#xff08;AI&#xff09;技术正以惊人的速度发展&#xff0c;从机器学习、深度学习再到自然语言处理和生成式模型&#xff0c;AI 的触角已延伸至各行各业。与此同时&#xff0c;一个新兴的概念逐渐受到关注——AIGC&#xff08;AI Generated Cont…

Linux中用户和用户管理详解

文章目录 Linux中用户和用户管理详解一、引言二、用户和用户组的基本概念1、用户账户文件2、用户组管理 三、用户管理操作1、添加用户2、设置用户密码3、删除用户 四、用户组操作1、创建用户组2、将用户添加到用户组 五、总结 Linux中用户和用户管理详解 一、引言 在Linux系统…

Android上传到Minio本地存储

Minio简介 MinIO是一个对象存储解决方案&#xff0c;它提供了与Amazon Web Services S3兼容的API&#xff0c;并支持所有核心S3功能。 MinIO有能力在任何地方部署 - 公有云或私有云&#xff0c;裸金属基础设施&#xff0c;编排环境&#xff0c;以及边缘基础设施。author: https…

Spring MVC 中,处理异常的 6种方式

异常处理是每个 Java程序员需要面对的一个问题&#xff0c;在Spring中&#xff0c;提供了多种机制来处理控制器抛出的异常&#xff0c;确保应用程序在面对各种错误情况时能够优雅地响应。这篇文章&#xff0c;我们来详细分析Spring MVC中&#xff0c;几种优雅处理异常的方式。 …