이런 상황에 직면해서 매개변수 없이 함수를 작성한 적이 있나요?
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개 이상이면 이 매개변수 객체를 사용하겠습니다.