찾다
웹 프론트엔드JS 튜토리얼Javascript_Basic 지식의 기본 매개변수에 대한 자세한 설명

Ruby, CoffeeScript 및 향후 JavaScript 버전과 같은 일부 언어는 함수를 정의할 때 다음과 같이 기본 매개변수를 선언할 수 있습니다.

코드 복사 코드는 다음과 같습니다.

function myFunc(param1, param2 = "두 번째 문자열") {
console.log(param1, param2);
}

// 출력: "첫 번째 문자열" 및 "두 번째 문자열"
myFunc("첫 번째 문자열");

// 출력: "첫 번째 문자열" 및 "두 번째 문자열 버전 2"
myFunc("첫 번째 문자열", "두 번째 문자열 버전 2");

안타깝게도 현재 버전의 자바스크립트에서는 이러한 작성 방식이 유효하지 않습니다. 그렇다면 기존 도구 세트를 사용하여 이를 달성하기 위해 무엇을 할 수 있습니까?

가장 간단한 해결책은 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.

함수 myFunc(param1, param2) {
If (param2 === 정의되지 않음) {
         param2 = "두 번째 문자열";
}

console.log(param1, param2);
}

// 출력: "첫 번째 문자열" 및 "두 번째 문자열 버전 2"
myFunc("첫 번째 문자열", "두 번째 문자열 버전 2");

사실 생략된 매개변수는 액세스할 때 항상 "정의되지 않음"입니다. 매개변수가 하나만 있는 경우 이는 좋은 솔루션이지만, 매개변수가 두 개 이상인 경우에는 어떻게 될까요?

매개변수가 두 개 이상인 경우 개체를 매개변수로 사용할 수 있으며, 이는 각 매개변수에 명확한 이름이 있다는 장점이 있습니다. 객체 매개변수를 전달하는 경우에도 동일한 방식으로 기본값을 선언할 수 있습니다.

코드 복사 코드는 다음과 같습니다.

함수 myFunc(paramObject) {
var defaultParams = {
         param1: "첫 번째 문자열",
         param2: "두 번째 문자열",
        param3: "세 번째 문자열"
};

var finalParams = defaultParams;

// paramObject의 각 속성을 반복합니다
for(paramObject의 var 키) {
// 현재 속성이 상속되지 않은 경우 진행
If (paramObject.hasOwnProperty(key)) {
                                   // 현재 속성이 정의된 경우
                          // finalParams에 추가
If (paramObject[key] !== 정의되지 않음) {
                     finalParams[키] = paramObject[키];
            }
}
}

console.log(finalParams.param1,
                     finalParams.param2,
                     finalParams.param3);
}
myFunc({param1: "나만의 문자열"});

이 방법을 여러 곳에서 사용하면 래퍼 함수를 ​​작성할 수 있지만 다행히 많은 라이브러리에는 이제 jQuery 및 Underscore의 확장 메서드와 같은 관련 메서드가 있습니다.

다음은 Underscore의 확장 메소드를 사용하여 위와 동일한 결과를 얻습니다.

코드 복사 코드는 다음과 같습니다.

함수 myFunc(paramObject) {
var defaultParams = {
         param1: "첫 번째 문자열",
         param2: "두 번째 문자열",
        param3: "세 번째 문자열"
};

var finalParams = _.extend(defaultParams, paramObject);

console.log(finalParams.param1,
                     finalParams.param2,
                     finalParams.param3);
}

// 출력:
// "나만의 문자열"과 "두 번째 문자열"과 "세 번째 문자열"
myFunc({param1: "나만의 문자열"});

이것은 현재 자바스크립트 버전에서 기본 매개변수를 얻는 방법입니다.

기사에 부정확한 내용이 있으면 비판과 수정을 환영합니다.

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
es6数组怎么去掉重复并且重新排序es6数组怎么去掉重复并且重新排序May 05, 2022 pm 07:08 PM

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

JavaScript的Symbol类型、隐藏属性及全局注册表详解JavaScript的Symbol类型、隐藏属性及全局注册表详解Jun 02, 2022 am 11:50 AM

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

原来利用纯CSS也能实现文字轮播与图片轮播!原来利用纯CSS也能实现文字轮播与图片轮播!Jun 10, 2022 pm 01:00 PM

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

JavaScript对象的构造函数和new操作符(实例详解)JavaScript对象的构造函数和new操作符(实例详解)May 10, 2022 pm 06:16 PM

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

JavaScript面向对象详细解析之属性描述符JavaScript面向对象详细解析之属性描述符May 27, 2022 pm 05:29 PM

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

javascript怎么移除元素点击事件javascript怎么移除元素点击事件Apr 11, 2022 pm 04:51 PM

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

foreach是es6里的吗foreach是es6里的吗May 05, 2022 pm 05:59 PM

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

整理总结JavaScript常见的BOM操作整理总结JavaScript常见的BOM操作Jun 01, 2022 am 11:43 AM

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

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음