자바스크립트 메소드 매개변수의 기본값을 설정하는 방법의 예_기본지식

WBOY
풀어 주다: 2016-05-16 15:31:38
원래의
1126명이 탐색했습니다.

이런 상황에 직면해서 매개변수 없이 함수를 작성한 적이 있나요?

function showUserInfo(){
alert("你好!我是小明。");
}

function showUserInfo(){ 
  alert("你好!我是小明。"); 
} 

로그인 후 복사

전화:

showUserInfo();

showUserInfo(); 

로그인 후 복사

나중에 이 함수가 다른 곳에서도 필요하다는 것을 알았는데, 일부 변수 값이 함수에 하드코딩되어 있었습니다. 어떻게 해야 할까요? 매개변수를 추가합니다.

function showUserInfo(name){
name=name||"小明";
alert("你好!我是"+name+"。");
}

function showUserInfo(name){ 
  name=name||"小明"; 
  alert("你好!我是"+name+"。"); 
} 

로그인 후 복사

설명: name=name||"Xiao Ming" 이 코드는 이름이 null인 경우 기본값 "Xiao Ming"과 동일함을 의미합니다. 다음과 같이 쓸 수도 있습니다.

function showUserInfo(name){
// name=name||"小明";
if(!name){
name="小明";
}
alert("你好!我是"+name+"。");
}

function showUserInfo(name){ 
// name=name||"小明"; 
  if(!name){ 
    name="小明"; 
  } 
  alert("你好!我是"+name+"。"); 
} 

로그인 후 복사


전화:

showUserInfo('小李');

showUserInfo('小李'); 

로그인 후 복사


나중에 요구 사항이 변경되어 연령을 추가해야 했습니다. 알았어, 바꿔보자:

function showUserInfo(name,age){
name=name||"小明";
age=age||22;
alert("你好!我是"+name+",今年"+age+"岁。");
}

function showUserInfo(name,age){ 
  name=name||"小明"; 
  age=age||22; 
  alert("你好!我是"+name+",今年"+age+"岁。"); 
} 

로그인 후 복사

전화:

showUserInfo('小李');//结果:你好!我是小李,今年22岁。
showUserInfo('小李',19);//结果:你好!我是小李,今年19岁。
showUserInfo(null,19);//结果:你好!我是小明,今年19岁。

showUserInfo('小李');//结果:你好!我是小李,今年22岁。 
showUserInfo('小李',19);//结果:你好!我是小李,今年19岁。 
showUserInfo(null,19);//结果:你好!我是小明,今年19岁。 

로그인 후 복사


자, 생일, 전화번호, 성별, QQ 등과 같은 매개변수를 추가해야 한다면 어떻게 될까요? 기본값을 하나씩 설정 하시겠습니까? 실제로 이런 일을 하는 사람들을 많이 봅니다. 더 간단한 방법을 살펴보겠습니다. 그것은 Jquery 확장을 사용하는 것입니다. 먼저 코드를 살펴보겠습니다.

function showUserInfo(setting){
var defaultSetting={
name:"小明",
age:"22",
sex:"男",
phone:"13888888888",
QQ:"12345678",
birthday:"1980.12.29"
};
$.extend(defaultSetting,settings);
var message='姓名:'+defaultSetting.name
+',性别:'+defaultSetting.sex
+',年龄:'+defaultSetting.age
+',电话:'+defaultSetting.phone
+',QQ:'+defaultSetting.QQ
+',生日:'+defaultSetting.birthday
+'。';
alert(message);
}


function showUserInfo(setting){ 
  var defaultSetting={ 
    name:"小明", 
    age:"22", 
    sex:"男", 
    phone:"13888888888", 
    QQ:"12345678", 
    birthday:"1980.12.29" 
  }; 
   
  $.extend(defaultSetting,settings); 
   
  var message='姓名:'+defaultSetting.name 
      +',性别:'+defaultSetting.sex 
      +',年龄:'+defaultSetting.age 
      +',电话:'+defaultSetting.phone 
      +',QQ:'+defaultSetting.QQ 
      +',生日:'+defaultSetting.birthday 
      +'。'; 
  alert(message); 
} 

로그인 후 복사

설명: $.extend(defaultSetting,settings)의 기능은 수신 설정 구성을 defaultSetting과 병합하고 defaultSetting 구성을 설정의 구성으로 덮어쓰는 것입니다.

전화:

showUserInfo({
name:"小李"
});
//结果:姓名:小李,性别:男,年龄:22,电话:13888888888,QQ:12345678,生日:1980.12.29。
showUserInfo({
name:"小红",
sex:"女",
phone:"13777777777"
});
//结果:姓名:小红,性别:女,年龄:22,电话:13777777777,QQ:12345678,生日:1980.12.29。




showUserInfo({ 
  name:"小李" 
}); 
//结果:姓名:小李,性别:男,年龄:22,电话:13888888888,QQ:12345678,生日:1980.12.29。 
showUserInfo({ 
  name:"小红", 
  sex:"女", 
  phone:"13777777777" 
}); 
//结果:姓名:小红,性别:女,年龄:22,电话:13777777777,QQ:12345678,生日:1980.12.29。 

로그인 후 복사


매우 간단합니다! 이렇게 하면 100개의 매개변수가 있어도 두렵지 않습니다.

그렇다면 언제 다중 매개변수를 사용해야 하며 언제 그러한 매개변수 객체를 사용해야 할까요? 내 경험에 따르면 실제 요구 사항에 따라 하나 또는 두 개의 매개 변수를 사용할 수 있으면 매개 변수 개체가 사용되지 않습니다. 3개 이상이면 이 매개변수 객체를 사용하겠습니다.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿