최근에 Express를 보다가 함수를 매개변수로 사용하는 콜백 함수를 곳곳에서 봤습니다. 이 개념을 이해하지 못하면 nodejs와 express의 코드가 엉망이 될 것입니다. 예:
app.use(function(req, res, next) {
var err = new Error('찾을 수 없음');
err.status = 404;
다음(err);
});
app은 객체이고, use는 메소드이고, 메소드의 매개변수는 매개변수가 있는 익명 함수이며, 함수 본문은 끝에 직접 제공됩니다. 이 코드를 이해하는 방법은 무엇입니까? 먼저 콜백 함수의 개념을 이해해 봅시다.
우선, js에서 함수는 변수에 할당될 수 있고 함수의 매개변수 목록에 매개변수로 배치될 수 있는 객체이기도 함을 이해해야 합니다. 예:
var doSomething = 함수(a,b)
{
b를 돌려주세요;
}
이 코드의 의미는 익명 함수를 정의하는 것입니다. 이 익명 함수에는 이름이 없다는 점만 제외하면 일반 함수와 다르지 않습니다. 그런 다음 익명 함수를 doSomething 변수에 할당합니다. 다음으로 호출할 내용은 다음과 같습니다.
console.log(doSomething(2,3));
이렇게 하면 5가 출력됩니다.
콜백 함수는 다른 함수(예: 상위)의 매개변수 목록에 배치되고 이 상위에 매개변수로 전달된 다음 상위 함수 본문의 어딘가에서 실행됩니다. 추상적입니다. 예를 살펴보겠습니다.
// 콜백의 개념을 설명하기 위해
var doit = 함수(콜백)
{
var a = 1,
b = 2,
c = 3;
var t = 콜백(a,b,c);
10시 반납;
};
var d = doit(함수(x,y,z){
반환(x y z);
});
console.log(d);
먼저 매개변수 콜백이 있는 doit 함수를 정의합니다. 이 콜백은 콜백 함수이며 이름은 임의로 지정할 수 있습니다. 함수 본문을 살펴보면 먼저 변수 a, b, c 세 개를 정의합니다. 그런 다음 콜백 함수를 호출합니다. 마지막으로 값을 반환합니다.
아래에서는 doit 함수를 호출합니다. 참고로 지금 막 doit을 정의했을 때는 콜백이 정의되어 있지 않아 콜백이 어떤 용도로 사용되는지 알 수 없었다. 이는 사실 이해하기 쉽습니다. 일반적으로 함수를 정의할 때 매개변수에는 a와 같은 이름만 부여하고, 함수 본문에서는 a를 사용하지만, 전체 프로세스는 그것을 호출할 때만 a가 무엇인지 알지 못합니다. function 그런 다음 a의 특정 값(예: 2)을 지정합니다. 돌이켜 보면 doit을 호출할 때 콜백이 무엇인지 지정해야 합니다. 보시다시피 이 함수는 합계 함수를 완성합니다.
위 코드의 실행 과정은 다음과 같습니다.
doit 함수를 호출합니다. 매개변수는 익명 함수입니다. doit의 함수 본문을 입력하고 먼저 a, b, c를 정의한 다음 방금 익명 함수를 실행합니다. 매개변수는 a, b, c이고 반환됩니다. a t, 그리고 마지막으로 A t 10을 반환하면 d가 제공됩니다.
원래 예로 돌아가서 app.use(...)는 함수 호출입니다. use 메소드가 이전에 정의되었음에 틀림없다고 생각할 수 있지만 여기서는 제공되지 않습니다. 이 두 가지 예를 비교해보면 바로 이해할 수 있습니다.
nodejs와 express를 사용할 때 모든 메소드나 함수의 함수 정의를 찾아서 살펴보는 것은 불가능합니다. 따라서 해당 정의에서 콜백에 어떤 매개변수가 전달되는지 알아보세요. 그런 다음 메소드나 함수를 호출할 때 특정 기능을 완성하기 위해 매개변수에 익명 함수를 직접 정의합니다.
끝!

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

드림위버 CS6
시각적 웹 개발 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구
