javascript 에서 call(),apply()의 차이

call(),apply()의 차이 점:
같은 점:
1.call()과 apply()는 함 수 를 간접 적 으로 호출 할 수 있 고 필요 한 this 를 명시 적 으로 호출 할 수 있 습 니 다.즉,모든 함 수 는 모든 대상 의 방법 으로 호출 할 수 있다.
2.두 가지 방법 모두 실제 참 조 를 지정 할 수 있다.
 구별:
call()과 apply()의 기본 적 인 차이 점:매개 변 수 를 함수 에 전달 하 는 것 입 니 다.
call():함수 의 매개 변수 로 자체 의 실제 인삼 목록 을 사용 합 니 다.
apply():매개 변 수 를 배열 로 입력 해 야 합 니 다.

function track(o,m){
    var original =o[m];
    o[m] =function( ){
      console.log(new Date(),m);
      var results =original.apply(this,arguments);
      console.log(new Date(),m);
      return results;
    }
  }
그들의 용법 은 주어진 예 를 통 해 설명 할 수 있다.

<script>
var someObject = {
  myProperty:'Foo',
  myMethod:function (prefix,posfix) {
    console.log(prefix + this.myProperty + posfix);
  }
};
someObject.myMethod('<','>');//Foo

var someOtherObject = {
  myProperty:'Bar'
};
someObject.myMethod.call(someOtherObject,'<','>');//Bar
someObject.myMethod.apply(someOtherObject,['<','>']);//Bar
</script>
위 에서 말 한 것 은 편집장 이 소개 한 자 바스 크 립 트 에서 콜(),apply()의 차 이 를 상세 하 게 해석 하고 통합 하 는 것 입 니 다.여러분 에 게 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 메 시 지 를 남 겨 주세요.편집장 은 제때에 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!

좋은 웹페이지 즐겨찾기