골때리는 자바스크립트의 세계 4탄

오랜만에 자바스크립트를 골때리게 하는 팁을 내놨습니다.

음.. 일단 먼저, 전 대통령의 서거를 애도합니다.

근데 문제는.. IT대통령이 역사속으로 사라졌으니 이제 대한민국 IT의 미래가 걱정되는군요.

어쨌든, 그런 의미에서 골때리는 자바스크립트를 통해 더욱 더 멋진 프로그램을 만들어야죠.

자, 아래 함수를 보세요.

somemethod()()()()()()();

…………………………………………………………………..??????????????????????????

자.. 처음부터 골때리죠? 하지만 이게 불가능할거라 생각하시면 뭐.. 그만 보고 나가도 좋습니다.

근데.. 가능합니다. 아니 대체 어떻게?

간단합니다. 음.. 어렵게 생각하실 필요는 없어요. 아래와 똑같으니까요.

somemethod();

somemethod();

somemethod();

somemethod();

somemethod();

somemethod();

음.. 똑같은 이름만 쓰는건 귀찮죠. 물론 컨트롤 씨브이 하면 되지만.. 용량 좀먹죠.

그래서 간단하게 괄호만 원하는 실행갯수만큼 주르르.

물론 재귀 함수는 맞습니다. 근데 재귀의 의미가 약간 벗어난다 싶지만

제가 워낙 삼천포를 가고 싶었거든요. 일단 소스는 다음과 같습니다.

function somemethod(){

  window.status+=”.”;

  return somemethod;

}

자. 보시면 함수 이름과 자기 자신을 리턴하는 모습입니다.

네. 자기 자신을 뱉어서 또 쓸 수 있게 되는거죠.

그렇게 되면 리턴값은 자신이 되는거고, 그리고 다시 불러올 수가 있죠.

이점이 뭐가 있냐면.. 일단 일반적인 재귀 함수를 봅시다.

var i=6;

function myfunc(){

  if(i>0){

    i–;

    myfunc();

  }

}

어째보면 이게 더 간단해 보이지만.. 왜 굳이 맨 위에방식을 쓰는겁니까.

글쎄요.. 저도 확연히 잡지를 않았지만 MVC 패턴에는.. 딱히 뭐라하기 그렇고..

그렇다고 눈에 확 띄는 코드라니 괄호만 도배하면 괄호세느라 뼈빠질테고..

결론은 그냥 이렇게 쓸 수 있구나 알아두세요.

차라리 재귀함수 쓸려면 이게 낫죠.

function myfunc(i){

  if(i<0){

    myfunc(i–);

  }

}

그래도 이게 그나마 숫자를 쓰니 보기도 쉽죠.

그래도.. 재밌게 코딩하는것도 남다른 자바스크립트의 재미가 아닐까요?

음.. 갑자기 분위기가 싸해졌군요. 자시 분위기 띄어보는 차원에서 골때리는 문제 하나 드리죠.

a=0;

function p(){

  (function(){this.a=’b’;a=’c’;})();

  var a=’d’;

  this.a=’e’;

  (function(){var a=this;(function(){a=’f’})();})();

}

p();

변수 a에 담길 값은 무엇일까요?

직접 머리로 디버그한번 해보세요. 다음에는 이 문제를 두고 다룰까 생각중입니다.

팁이 좀 짧군요. 제가 지금 슬럼프라 뭐라할말이 없지만..

다음 팁은 더욱더 무엇보다도 골때리도록 노력해보겠습니다.

License:Public Domain

composite / 2010년 12월 13일 / 미분류

답글 남기기

Your email address will not be published / Required fields are marked *