走进 JavaScript 世界:掌握核心技能

目录

一、引言

二、JavaScript 基础

(一)历史与特点

脚本语言

与 HTML 和 CSS 紧密结合

事件驱动和异步执行

(二)语法基础

变量与数据类型

运算符与表达式

控制结构

条件语句

循环语句

(三)函数

函数定义

函数参数

函数返回值

三、JavaScript 面向对象编程

(一)对象概述

对象的定义

对象的属性和方法

(二)原型链

原型的概念

原型链的形成

(三)继承

原型继承

借用构造函数继承

组合继承

四、JavaScript DOM 操作

(一)DOM 概述

DOM 的概念

DOM 树的结构

(二)DOM 操作方法

获取元素

创建元素

添加元素

删除元素

修改元素属性

修改元素内容

(三)事件处理

事件模型

事件绑定

事件触发

五、JavaScript 事件处理

(一)事件类型

鼠标事件

键盘事件

表单事件

(二)事件处理函数

内联事件处理函数

HTML5 事件处理属性

(三)事件冒泡与捕获

事件冒泡

事件捕获

六、JavaScript 定时器与事件循环

(一)定时器

setTimeout()函数

setInterval()函数

(二)事件循环

事件循环的概念

任务队列

七、JavaScript 函数式编程

(一)函数式编程概述

函数式编程的概念

JavaScript 中的函数式编程

(二)高阶函数

(三)函数柯里化

(四)闭包


一、引言

JavaScript 作为一种广泛应用于网页开发的脚本语言,已经成为现代 Web 开发的核心技术之一。它具有丰富的功能和灵活的语法,能够为网页添加交互性、动态效果和丰富的用户体验。无论是创建简单的网页表单验证,还是构建复杂的单页应用程序(SPA)和全栈 Web 应用,JavaScript 都发挥着至关重要的作用。本文将深入探讨 JavaScript 的各个方面,帮助您全面了解和掌握这门强大的语言。

二、JavaScript 基础

(一)历史与特点

JavaScript 诞生于 20 世纪 90 年代末期,最初是为了在网页中实现交互功能而设计的。它具有以下特点:

  • 脚本语言
    • JavaScript 是一种解释型语言,这意味着它不需要编译,可以直接在浏览器中运行。代码在发送到浏览器后,由浏览器的解释器逐行解释执行。
    • 它的语法相对简单,易于学习和掌握,适合快速开发和原型设计。
  • 与 HTML 和 CSS 紧密结合
    • JavaScript 可以直接嵌入到 HTML 文件中,通过<script>标签来定义。它能够操作 HTML 文档的结构、样式和内容,实现页面的动态更新和交互效果。
    • 同时,JavaScript 也可以与 CSS 配合使用,通过修改元素的样式来实现动画效果和视觉交互
  • 事件驱动和异步执行
    • JavaScript 通过事件驱动的方式来响应用户的操作和浏览器的行为。例如,当用户点击按钮、提交表单或滚动页面时,可以触发相应的事件处理函数来执行相应的操作。
    • 它还支持异步执行,能够在不阻塞页面加载的情况下进行网络请求、定时器操作等,提高了网页的性能和响应性。

(二)语法基础

  1. 变量与数据类型
    • 变量声明:在 JavaScript 中,可以使用varletconst关键字来声明变量。var声明的变量存在变量提升的问题,可能会导致一些意外的行为;letconst则不存在变量提升,并且const声明的是常量,一旦赋值后就不能再修改。
    • 数据类型
      • 基本数据类型:包括数字(number)、字符串(string)、布尔值(boolean)、nullundefined。数字类型可以是整数或浮点数,字符串类型可以使用单引号或双引号括起来,布尔值只有truefalse两个值,null表示空值,undefined表示未定义的值。
      • 引用数据类型:包括对象(object)、数组(array)和函数(function)。对象是一组键值对的集合,数组是一种特殊的对象,用于存储一组值,函数是可执行的代码块。
  2. 运算符与表达式
    • 算术运算符:包括加法(+)、减法(-)、乘法(*)、除法(/)、取余(%)等。这些运算符可以用于对数字类型的数据进行运算。
    • 比较运算符:包括大于(>)、小于(<)、大于等于(>=)、小于等于(<=)、等于(==)和严格等于(===)等。比较运算符用于比较两个值的大小或是否相等。
    • 逻辑运算符:包括与(&&)、或(||)、非(!)等。逻辑运算符用于组合多个条件,实现逻辑判断。
    • 表达式:表达式是由运算符和操作数组成的式子,它可以计算出一个值。例如,2 + 3是一个表达式,它的计算结果是5
  3. 控制结构
    • 条件语句
      • if-else 语句:根据条件的真假来执行不同的代码块。例如:
      if (condition) {
          // 条件为真时执行的代码
      } else {
          // 条件为假时执行的代码
      }
      
       
      • switch 语句:根据表达式的值来选择执行不同的代码块。例如:
      switch (expression) {
          case value1:
              // 当表达式的值等于value1时执行的代码
              break;
          case value2:
              // 当表达式的值等于value2时执行的代码
              break;
          default:
              // 当表达式的值不等于任何一个case的值时执行的代码
      }
      
    • 循环语句
      • for 循环:用于重复执行一段代码,通常用于遍历数组或执行固定次数的操作。例如:
      for (initialization; condition; increment) {
          // 循环体代码
      }
      
       
      • while 循环:只要条件为真,就会一直执行循环体代码。例如:
      while (condition) {
          // 循环体代码
      }
      
       
      • do-while 循环:先执行一次循环体代码,然后再判断条件是否为真,如果为真则继续执行循环体代码。例如:
      do {
          // 循环体代码
      } while (condition);
      

(三)函数

  1. 函数定义
    • 函数声明:使用function关键字来声明函数,例如:
    function functionName() {
        // 函数体代码
    }
    
     
    • 函数表达式:将函数赋值给一个变量,例如:
    var functionName = function() {
        // 函数体代码
    };
    
  2. 函数参数
    • 函数可以接受零个或多个参数,参数在函数定义时指定,在调用函数时传递相应的值。例如:
    function addNumbers(num1, num2) {
        return num1 + num2;
    }
    
    var result = addNumbers(5, 10);
    
  3. 函数返回值
    • 函数可以使用return关键字来返回一个值,返回值的类型可以是任何数据类型。例如:
    function getFullName(firstName, lastName) {
        return firstName + " " + lastName;
    }
    
    var fullName = getFullName("John", "Doe");
    

三、JavaScript 面向对象编程

(一)对象概述

  1. 对象的定义
    • 在 JavaScript 中,对象是一种无序的数据集合,它由属性和方法组成。可以使用字面量语法或构造函数来创建对象。
    • 字面量语法:使用花括号{}来创建对象,例如:
    var person = {
        name: "John",
        age: 30,
        greet: function() {
            console.log("Hello, my name is " + this.name + " and I am " + this.age + " years old.");
        }
    };
    
     
    • 构造函数语法:使用函数作为构造函数来创建对象,例如:
    function Person(name, age) {
        this.name = name;
        this.age = age;
        this.greet = function() {
            console.log("Hello, my name is " + this.name + " and I am " + this.age + " years old.");
        };
    }
    
    var person = new Person("John", 30);
    
  2. 对象的属性和方法
    • 属性:对象的属性是用于存储数据的键值对,属性可以是任何数据类型,例如字符串、数字、对象等。可以通过点操作符或方括号操作符来访问对象的属性,例如:
    var person = {
        name: "John",
        age: 30
    };
    
    console.log(person.name); // 使用点操作符
    console.log(person["name"]); // 使用方括号操作符
    
     
    • 方法:对象的方法是用于执行操作的函数,方法可以通过点操作符或方括号操作符来调用,例如:
    var person = {
        name: "John",
        age: 30,
        greet: function() {
            console.log("Hello, my name is " + this.name + " and I am " + this.age + " years old.");
        }
    };
    
    person.greet();
    

(二)原型链

  1. 原型的概念
    • 在 JavaScript 中,每个对象都有一个原型对象,原型对象包含了一些共享的属性和方法。当访问对象的属性或方法时,如果对象本身没有该属性或方法,则会从原型对象中查找。
    • 可以使用__proto__属性来访问对象的原型对象,但是这种方式不推荐使用,因为它不是标准的 JavaScript 语法。更好的方式是使用Object.getPrototypeOf()方法来获取对象的原型对象。
  2. 原型链的形成
    • 每个函数都有一个prototype属性,该属性指向函数的原型对象。当使用构造函数创建对象时,对象的__proto__属性会指向构造函数的原型对象,从而形成原型链。
    • 在原型链中,每个对象都可以访问到其原型对象中的属性和方法,直到找到最顶层的原型对象(即Object.prototype)为止。如果在原型链中没有找到所需的属性或方法,则会返回undefined

(三)继承

  1. 原型继承
    • 原型继承是 JavaScript 中实现继承的一种常见方式,它通过将子对象的原型对象设置为父对象的实例来实现继承。这样,子对象就可以访问到父对象的属性和方法。
    • 以下是一个使用原型继承的示例代码:
    function Parent() {
        this.parentProperty = "This is a parent property.";
    }
    
    Parent.prototype.parentMethod = function() {
        console.log("This is a parent method.");
    };
    
    function Child() {
        this.childProperty = "This is a child property.";
    }
    
    Child.prototype = new Parent();
    Child.prototype.constructor = Child;
    
    var child = new Child();
    console.log(child.parentProperty); // 输出:This is a parent property.
    child.parentMethod(); // 输出:This is a parent method.
    
  2. 借用构造函数继承
    • 借用构造函数继承是另一种实现继承的方式,它通过在子函数中调用父函数来实现继承。在子函数中,可以使用this关键字来访问和设置父函数的属性和方法。
    • 以下是一个使用借用构造函数继承的示例代码:
    function Parent() {
        this.parentProperty = "This is a parent property.";
    }
    
    Parent.prototype.parentMethod = function() {
        console.log("This is a parent method.");
    };
    
    function Child() {
        Parent.call(this);
        this.childProperty = "This is a child property.";
    }
    
    var child = new Child();
    console.log(child.parentProperty); // 输出:This is a parent property.
    child.parentMethod(); // 错误:parentMethod不是child的方法
    
  3. 组合继承
    • 组合继承是原型继承和借用构造函数继承的结合,它既保留了原型继承的优点,又解决了借用构造函数继承中无法共享原型方法的问题。
    • 以下是一个使用组合继承的示例代码:
    function Parent() {
        this.parentProperty = "This is a parent property.";
    }
    
    Parent.prototype.parentMethod = function() {
        console.log("This is a parent method.");
    };
    
    function Child() {
        Parent.call(this);
        this.childProperty = "This is a child property.";
    }
    
    Child.prototype = new Parent();
    Child.prototype.constructor = Child;
    
    var child = new Child();
    console.log(child.parentProperty); // 输出:This is a parent property.
    child.parentMethod(); // 输出:This is a parent method.
    

四、JavaScript DOM 操作

(一)DOM 概述

  1. DOM 的概念
    • DOM(Document Object Model)是 W3C 标准定义的一种与平台和语言无关的接口,它将 HTML 或 XML 文档表示为一个树形结构,其中每个节点代表文档中的一个元素属性文本节点
    • 通过 DOM API,开发人员可以使用 JavaScript 来操作 HTML 文档的结构、样式和内容,实现页面的动态更新和交互效果
  2. DOM 树的结构
    • DOM 树的根节点是document对象,它代表整个 HTML 文档。document对象下面包含了headbody等节点,head节点下面包含了metatitle等节点,body节点下面包含了各种 HTML 元素节点,如divpinput等。每个节点都可以有子节点、父节点和兄弟节点。

(二)DOM 操作方法

  1. 获取元素
    • getElementById():根据元素的id属性值来获取单个元素,例如:
    var element = document.getElementById("myElement");
    
     
    • getElementsByTagName():根据元素的标签名来获取一组元素,例如:
    var elements = document.getElementsByTagName("div");
    
     
    • getElementsByClassName():根据元素的类名来获取一组元素,例如:
    var elements = document.getElementsByClassName("myClass");
    
  2. 创建元素
    • createElement():创建一个新的 HTML 元素,例如:
    var newElement = document.createElement("div");
    
  3. 添加元素
    • appendChild():将一个元素添加到另一个元素的子节点列表的末尾,例如:
    var parentElement = document.getElementById("parentElement");
    var newElement = document.createElement("div");
    parentElement.appendChild(newElement);
    
  4. 删除元素
    • removeChild():从父元素中删除一个子元素,例如:
    var parentElement = document.getElementById("parentElement");
    var childElement = document.getElementById("childElement");
    parentElement.removeChild(childElement);
    
  5. 修改元素属性
    • setAttribute():设置元素的属性值,例如:
    var element = document.getElementById("myElement");
    element.setAttribute("name", "value");
    
     
    • getAttribute():获取元素的属性值,例如:
    var element = document.getElementById("myElement");
    var attributeValue = element.getAttribute("name");
    
  6. 修改元素内容
    • innerHTML:设置或获取元素的 HTML 内容,例如:
    var element = document.getElementById("myElement");
    element.innerHTML = "<p>New content</p>";
    
     
    • textContent:设置或获取元素的文本内容,不包括 HTML 标签,例如:
    var element = document.getElementById("myElement");
    element.textContent = "New text";
    

(三)事件处理

  1. 事件模型
    • JavaScript 的事件模型包括捕获阶段和冒泡阶段。在捕获阶段,事件从文档的根节点开始向下传播,直到到达目标元素;在冒泡阶段,事件从目标元素开始向上传播,直到到达文档的根节点。
    • 默认情况下,事件处理程序是在冒泡阶段触发的,但可以通过设置capture参数来指定事件处理程序在捕获阶段触发。
  2. 事件绑定
    • addEventListener():为元素添加事件处理程序,例如:
    var element = document.getElementById("myElement");
    element.addEventListener("click", function() {
        // 事件处理逻辑
    }, false);
    
     
    • 上述代码为idmyElement的元素添加了一个点击事件处理程序,当用户点击该元素时,会执行事件处理函数中的逻辑。
  3. 事件触发
    • 可以通过手动触发事件来模拟用户的操作,例如:
    var event = new Event("myEvent");
    document.dispatchEvent(event);
    
      上述代码创建了一个自定义事件myEvent,并通过dispatchEvent()方法将该事件发送到文档中,从而触发与该事件相关的事件处理程序。

五、JavaScript 事件处理

(一)事件类型

  1. 鼠标事件
    • click:当用户点击元素时触发。
    • dblclick:当用户双击元素时触发。
    • mouseenter:当鼠标指针进入元素时触发。
    • mouseleave:当鼠标指针离开元素时触发。
    • mousemove:当鼠标指针在元素内部移动时触发。
  2. 键盘事件
    • keydown:当用户按下键盘上的任意键时触发。
    • keyup:当用户松开键盘上的任意键时触发。
    • keypress:当用户按下并松开键盘上的字符键时触发。
  3. 表单事件
    • submit:当用户提交表单时触发。
    • reset:当用户重置表单时触发。
    • change:当表单元素的值发生改变时触发。
    • input:当表单元素的值发生改变时触发,与change事件的区别在于input事件会在每次输入时触发,而change事件只会在元素失去焦点时触发。

(二)事件处理函数

  1. 内联事件处理函数
    • 在 HTML 标签中,可以使用onclickondblclickonmouseenter等属性来指定事件处理函数,例如:
    <button onclick="handleClick()">Click me</button>
    
      上述代码在button元素中使用onclick属性指定了一个点击事件处理函数handleClick(),当用户点击按钮时,会执行该函数。
  2. HTML5 事件处理属性
    • HTML5 引入了一些新的事件处理属性,如addEventListener()removeEventListener(),它们可以在 JavaScript 中动态地添加和删除事件处理程序,例如:
    <button id="myButton">Click me</button>
    
    var button = document.getElementById("myButton");
    button.addEventListener("click", function() {
        console.log("Button clicked");
    });
    
  3. JavaScript 事件处理函数
    • 在 JavaScript 中,可以使用函数来处理事件,例如:
    function handleClick() {
        console.log("Button clicked");
    }
    
    var button = document.getElementById("myButton");
    button.onclick = handleClick;
    
      上述代码定义了一个名为handleClick()的函数,并将其赋值给button元素的onclick属性,当用户点击按钮时,会执行handleClick()函数。

(三)事件冒泡与捕获

  1. 事件冒泡
    • 事件冒泡是 JavaScript 事件处理的默认机制,当一个元素触发某个事件时,该事件会从目标元素开始向上传播,依次触发父元素的相同事件处理程序,直到到达文档的根节点。
    • 以下是一个事件冒泡的示例代码:
    <div onclick="parentHandler()">
        <button onclick="childHandler()">Click me</button>
    </div>
    
    function childHandler() {
        console.log("Child element clicked");
    }
    
    function parentHandler() {
        console.log("Parent element clicked");
    }
    
      当用户点击按钮时,会先触发childHandler()函数,然后再触发parentHandler()函数。
  2. 事件捕获
    • 事件捕获与事件冒泡相反,它是从文档的根节点开始向下传播,直到到达目标元素,然后再触发目标元素的事件处理程序。
    • 可以通过设置addEventListener()方法的第三个参数来指定事件处理程序是在捕获阶段还是冒泡阶段触发,例如:
    var element = document.getElementById("myElement");
    element.addEventListener("click", function() {
        console.log("Element clicked");
    }, true); // 设置为捕获阶段触发
    
      上述代码为idmyElement的元素添加了一个点击事件处理程序,并将第三个参数设置为true,表示事件处理程序在捕获阶段触发。

六、JavaScript 定时器与事件循环

(一)定时器

  1. setTimeout()函数
    • setTimeout()函数用于设置一个定时器,该函数接受两个参数:第一个参数是要执行的函数或字符串,表示要执行的代码;第二个参数是延迟时间,以毫秒为单位。
    • 以下是一个使用setTimeout()函数的示例代码:
    setTimeout(function() {
        console.log("Timeout executed");
    }, 2000);
    
      上述代码设置了一个定时器,该定时器会在 2 秒后执行指定的函数,并输出一条消息。
  2. setInterval()函数
    • setInterval()函数用于设置一个周期性执行的定时器,该函数接受两个参数:第一个参数是要执行的函数或字符串,表示要执行的代码;第二个参数是执行周期,以毫秒为单位。
    • 以下是一个使用setInterval()函数的示例代码:
    var intervalId = setInterval(function() {
        console.log("Interval executed");
    }, 1000);
    
    // 可以使用`clearInterval()`函数来清除定时器
    setTimeout(function() {
        clearInterval(intervalId);
    }, 5000);
    
      上述代码设置了一个周期性执行的定时器,该定时器会每隔 1 秒执行一次指定的函数,并输出一条消息。在 5 秒后,使用clearInterval()函数清除了定时器。

(二)事件循环

  1. 事件循环的概念
    • JavaScript 是单线程语言,这意味着它在同一时间只能执行一个任务。但是,由于浏览器需要处理各种事件,如用户操作、网络请求等,因此 JavaScript 引入了事件循环机制来处理异步任务。
    • 事件循环是一个不断循环的过程,它会检查任务队列中是否有任务需要执行。如果有任务需要执行,事件循环会将任务从任务队列中取出,并在主线程中执行该任务。当任务执行完毕后,事件循环会继续检查任务队列中是否有其他任务需要执行。
  2. 任务队列
    • 任务队列是一个存储异步任务的队列,包括定时器任务、事件回调函数等。当异步任务完成时,它们会被添加到任务队列中,等待事件循环来执行。
    • 事件循环会按照任务的优先级添加顺序来执行任务队列中的任务。

七、JavaScript 函数式编程

(一)函数式编程概述

  1. 函数式编程的概念
    • 函数式编程是一种编程范式,它强调使用函数来处理数据,而不是使用变量和状态。在函数式编程中,函数是一等公民,它们可以作为参数传递给其他函数,也可以作为返回值返回 from another function.
    • 函数式编程的主要特点包括:使用纯函数、避免副作用、不可变数据等。
  2. JavaScript 中的函数式编程
    • JavaScript 支持函数式编程的一些特性,如高阶函数、函数柯里化、闭包等。这些特性可以帮助我们编写更简洁、可维护和可测试的代码。

(二)高阶函数

  1. 高阶函数的概念
    • 高阶函数是指那些可以接受函数作为参数或返回函数的函数。高阶函数是函数式编程的重要概念之一,它可以帮助我们实现代码的复用和抽象。
    • 以下是一些 JavaScript 中常见的高阶函数:
      • map()函数:用于对数组中的每个元素应用一个函数,并返回一个新的数组。
      • filter()函数:用于过滤数组中的元素,返回一个新的数组,其中包含符合条件的元素。
      • reduce()函数:用于对数组中的元素进行累积计算,返回一个最终的结果。
  2. 示例代码
    // 使用map()函数对数组进行映射
    var numbers = [1, 2, 3, 4, 5];
    var doubledNumbers = numbers.map(function(number) {
        return number * 2;
    });
    console.log(doubledNumbers); // 输出:[2, 4, 6, 8, 10]
    
    // 使用filter()函数过滤数组
    var numbers = [1, 2, 3, 4, 5];
    var evenNumbers = numbers.filter(function(number) {
        return number % 2 === 0;
    });
    console.log(evenNumbers); // 输出:[2, 4]
    
    // 使用reduce()函数对数组进行累积计算
    var numbers = [1, 2, 3, 4, 5];
    var sum = numbers.reduce(function(accumulator, currentValue) {
        return accumulator + currentValue;
    }, 0);
    console.log(sum); // 输出:15
    

(三)函数柯里化

  1. 函数柯里化的概念
    • 函数柯里化是一种将多参数函数转换为一系列单参数函数的技术。通过函数柯里化,可以在调用函数时逐步传递参数,从而实现更灵活的函数调用方式。
    • 以下是一个函数柯里化的示例代码:
    function addNumbers(a, b, c) {
        return a + b + c;
    }
    
    var addTwoNumbers = curry(addNumbers);
    
    function curry(func) {
        return function(a) {
            return function(b) {
                return function(c) {
                    return func(a, b, c);
                };
            };
        };
    }
    
    var result = addTwoNumbers(1)(2)(3);
    console.log(result); // 输出:6
    
      在上述代码中,定义了一个addNumbers()函数和一个curry()函数。curry()函数用于实现函数柯里化,它返回一个新的函数addTwoNumbers(),该函数接受第一个参数a,并返回一个新的函数,该函数接受第二个参数b,并返回一个新的函数,该函数接受第三个参数c,最后调用addNumbers()函数计算结果。

(四)闭包

  1. 闭包的概念
    • 闭包是指有权访问另一个函数作用域中的变量的函数。闭包可以实现数据的隐藏和封装,同时也可以实现函数的柯里化函数式编程中的一些特性。
    • 以下是一个闭包的示例代码:
    function multiplier(factor) {
        return function(number) {
            return number * factor;
        };
    }
    
    var doubler = multiplier(2);
    var tripler = multiplier(3);
    
    console.log(doubler(5)); // 输出:10
    console.log(tripler(5)); // 输出:15
    

    在上述代码中,multiplier()函数返回一个函数,这个返回的函数可以访问到multiplier()函数内部的变量factor。以下是对这段代码的详细分析:

  2. 函数功能
    • multiplier()函数用于创建一个乘法器函数。它接受一个参数factor,该参数将用于后续的乘法运算。
  3. 返回值
    • multiplier()函数返回一个新的函数。这个新函数接受一个参数number,并返回numbermultiplier()函数的参数factor的乘积。
  4. 代码示例解释
    • 当调用multiplier(2)时,返回的函数doubler会将传入的参数乘以 2。例如,doubler(5)的结果是 10。
    • 当调用multiplier(3)时,返回的函数tripler会将传入的参数乘以 3。例如,tripler(5)的结果是 15。
  5. 扩展功能
    • 可以在multiplier()函数中添加更多的逻辑,例如对factor进行验证或限制,以确保返回的函数的行为符合预期。
    • 还可以考虑添加一些错误处理机制,以处理传入无效参数的情况。
  6. 添加错误处理
    function multiplier(factor) {
        if (typeof factor!=='number') {
            throw new Error('Factor must be a number');
        }
        return function(number) {
            return number * factor;
        };
    }
    
  7. 模拟私有变量
    function multiplier() {
        var privateFactor = 2; // 模拟私有变量
    
        return function(number) {
            return number * privateFactor;
        };
    }
    
    var doubler = multiplier();
    console.log(doubler(5)); // 输出:10
    
  8. 扩展函数参数
    function multiplier(factor, prefix) {
        if (typeof factor!=='number') {
            throw new Error('Factor must be a number');
        }
        return function(number) {
            return prefix +'x '+ number +'='+ (number * factor);
        };
    }
    
    var doubler = multiplier(2, 'Double');
    console.log(doubler(5)); // 输出:Double x 5 = 10
    • 应用场景
      • 这种闭包的用法在许多场景中都非常有用,例如创建具有不同配置的函数、实现装饰器模式、模拟私有变量等。
      • 在实际开发中,可以根据具体需求,灵活运用闭包来提高代码的质量和可维护性。

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

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

相关文章

消息中间件类型介绍

消息中间件是一种在分布式系统中用于实现消息传递的软件架构模式。它能够在不同的系统或应用之间异步地传输数据&#xff0c;实现系统的解耦、提高系统的可扩展性和可靠性。以下是几种常见的消息中间件类型及其介绍&#xff1a; 1.RabbitMQ 特点&#xff1a; • 基于AMQP&#…

uniapp使用scss mixin抽离css常用的公共样式

1、编写通用scss样式文件 // 通用 Flex Mixin mixin flex($direction: row, $justify: flex-start, $align: stretch, $wrap: nowrap) {display: flex;flex-direction: $direction;justify-content: $justify;align-items: $align;flex-wrap: $wrap; }// 水平居中 mixin flex-…

Matlab Steger算法提取条纹中心线(亚像素位置)

文章目录 一、简介二、实现代码三、实现效果参考文献一、简介 Steger 算法是一种常用的图像边缘检测算法,可以用于提取图像中的中心线或边缘信息。它的理论假设是:条纹的亮度是按照高斯分布呈现的,即中心亮两侧渐暗。 其计算过程如下所述: 1、首先,我们需要计算每个点Hess…

PySide6 Qt for Python Qt Quick参考网址

Qt QML BOOK&#xff1a; 《Qt for Python》 -Building an Application https://www.qt.io/product/qt6/qml-book/ch19-python-build-app#signals-and-slots Qt for Python&#xff1a;与C版本的差异即BUG处理&#xff08;常见的DLL文件确实的问题等&#xff09; Qt for Pyt…

【大数据】Apache Superset:可视化开源架构

Apache Superset是什么 Apache Superset 是一个开源的现代化数据可视化和数据探索平台&#xff0c;主要用于帮助用户以交互式的方式分析和展示数据。有不少丰富的可视化组件&#xff0c;可以将数据从多种数据源&#xff08;如 SQL 数据库、数据仓库、NoSQL 数据库等&#xff0…

ELK实战(最详细)

一、什么是ELK ELK是三个产品的简称&#xff1a;ElasticSearch(简称ES) 、Logstash 、Kibana 。其中&#xff1a; ElasticSearch&#xff1a;是一个开源分布式搜索引擎Logstash &#xff1a;是一个数据收集引擎&#xff0c;支持日志搜集、分析、过滤&#xff0c;支持大量数据…

汽车物资拍卖系统架构与功能分析

2015工作至今&#xff0c;10年资深全栈工程师&#xff0c;CTO&#xff0c;擅长带团队、攻克各种技术难题、研发各类软件产品&#xff0c;我的代码态度&#xff1a;代码虐我千百遍&#xff0c;我待代码如初恋&#xff0c;我的工作态度&#xff1a;极致&#xff0c;责任&#xff…

利用 Python 爬虫从义乌购根据关键词获取商品列表

在当今数字化商业时代&#xff0c;数据是企业获取竞争优势的关键。对于从事国际贸易的商家而言&#xff0c;能够及时、准确地获取商品信息至关重要。义乌购作为知名的国际贸易批发平台&#xff0c;汇集了海量的商品资源。通过 Python 爬虫技术&#xff0c;我们可以高效地从义乌…

HDFS编程 - 使用HDFS Java API进行文件操作

文章目录 前言一、创建hdfs-demo项目1. 在idea上创建maven项目2. 导入hadoop相关依赖 二、常用 HDFS Java API1. 简介2. 获取文件系统实例3. 创建目录4. 创建文件4.1 创建文件并写入数据4.2 创建新空白文件 5. 查看文件内容6. 查看目录下的文件或目录信息6.1 查看指定目录下的文…

直流无刷电机控制(FOC):电流模式

目录 概述 1 系统框架结构 1.1 硬件模块介绍 1.2 硬件实物图 1.3 引脚接口定义 2 代码实现 2.1 软件架构 2.2 电流检测函数 3 电流环功能实现 3.1 代码实现 3.2 测试代码实现 4 测试 概述 本文主要介绍基于DengFOC的库函数&#xff0c;实现直流无刷电机控制&#x…

51单片机——串口通信(重点)

1、通信 通信的方式可以分为多种&#xff0c;按照数据传送方式可分为串行通信和并行通信&#xff1b; 按照通信的数据同步方式&#xff0c;可分为异步通信和同步通信&#xff1b; 按照数据的传输方向又可分为单工、半双工和全双工通信 1.1 通信速率 衡量通信性能的一个非常…

如何在 Linux、MacOS 以及 Windows 中打开控制面板

控制面板不仅仅是一系列图标和菜单的集合&#xff1b;它是通往优化个人计算体验的大门。通过它&#xff0c;用户可以轻松调整从外观到性能的各种参数&#xff0c;确保他们的电脑能够完美地适应自己的需求。无论是想要提升系统安全性、管理硬件设备&#xff0c;还是简单地改变桌…

浅谈弱电系统RVVP和RVSP电缆的区别(

1、RVVP 1.1RVVP电缆定义&#xff1f; RVVP电缆抗干扰软电缆、屏蔽电缆、信号电缆、控制电缆&#xff08;名字很多&#xff09;&#xff0c;学名&#xff1a;铜芯-聚氯乙烯绝缘-屏蔽聚氯乙烯护套-软电缆。 1.2RVVP执行标准 主要执行标准为JB/T8734.5-2016&#xff0c;部…

Python的pandas库基础知识(超详细教学)

目录 一、配置环境 二、序列和数据表 2.1 初始化 2.2 获取数值 2.3 获取索引 2.4 索引取内容 2.5 索引改变取值 2.6 字典生成序列 2.7 计算取值出现次数 2.8 数据表 2.9 数据表添加新变量 2.10 获取列名 2.11 根据列名获取数据 2.12 输出固定行 2.13 输出多行…

Mysql--基础篇--SQL(DDL,DML,窗口函数,CET,视图,存储过程,触发器等)

SQL&#xff08;Structured Query Language&#xff0c;结构化查询语言&#xff09;是用于管理和操作关系型数据库的标准语言。它允许用户定义、查询、更新和管理数据库中的数据。SQL是一种声明性语言&#xff0c;用户只需要指定想要执行的操作&#xff0c;而不需要详细说明如何…

【Rust自学】11.5. 在测试中使用Result<T, E>

喜欢的话别忘了点赞、收藏加关注哦&#xff0c;对接下来的教程有兴趣的可以关注专栏。谢谢喵&#xff01;(&#xff65;ω&#xff65;) 11.5.1. 测试函数返回值为Result枚举 到目前为止&#xff0c;测试运行失败的原因都是因为触发了panic&#xff0c;但可以导致测试失败的…

【Linux】gawk编辑器

一、基本介绍 相较于sed编辑器来说&#xff0c;gawk提供了一种编程语言&#xff0c;而不仅仅是编辑器命令。 在gawk编程语言中&#xff0c;可以实现以下操作&#xff1a; 定义变量来保存数据&#xff1b;使用算术和字符串运算符来处理数据&#xff1b;使用结构化编程语法&…

Backend - C# asp .net core

目录 一、各大框架理解 &#xff08;一&#xff09;ASP.NET Core &#xff08;二&#xff09;ASP.NET Core Web Application &#xff08;三&#xff09;ASP.NET Core MVC &#xff08;四&#xff09;ASP.NET Core Web API &#xff08;五&#xff09;ASP.NET Core 和 EF …

麦田物语学习笔记:背包物品选择高亮显示和动画

如题,本篇文章没讲动画效果 基本流程 1.代码思路 (1)先用点击事件的接口函数去实现,点击后反转选择状态(isSelected),以及设置激活状态(SetActive),并且还需要判断该格子是否为空,空格子是点不动的,完成后以上后,出现的问题是高亮应该是有且仅有一个格子是高亮的,而现在可以让…

自定义音频播放样式结合Howler.js

滑动式滚动条 不使用audio默认样式 自定义音频播放样式 当前时间 开始时间 结束时间 可播放可暂停 滚动条可拖动进行同步 具体样式可调整npm install howler --save<template><div class"audio-player"><div v-if"isLoading" class"l…