도비는 여전히 jQuery 마이그레이션 작업 중.

2022.05.17 - [개발/javascript] - jQuery 마이그레이션 - Deprecated, Removed
jQuery 마이그레이션 - Deprecated, Removed
jQuery 1.12.1 쓰던 사이트에서 보안 이슈로 3.6.0으로 마이그레이션 작업 중. 사이트의 구조와 환경이 괴랄하여 한 땀 한 땀 장인 정신으로 수정해야 하는 상황이다. https://api.jquery.com/category/deprecated.
naveen.tistory.com

.selector 가 removed 되었다고 있어서 이게 뭔 소린가 하고 찬찬히 살펴보았다.
미친 듯이 구글링을 했다는 소리다.
$.fn.newPlugin 같이 플러그인 내부에서 jQuery 오브젝트를 참조할 때 this.selector 로 현재 selector 를 참조할 수 있었던 기능이 없어졌다는 소리다.
https://github.com/jquery/jquery/issues/1908
Remove context and selector properties · Issue #1908 · jquery/jquery
Originally reported for jQuery 2.0.3 by anonymous at http://bugs.jquery.com/ticket/14341 I was lurking a few months ago and just remembered now, but it looks like both these properties are still pr...
github.com
관련 문서는 이거.
$.fn.test = function() {
    console.log(this.selector, this.context);
    return this;
};
(function() {
    $('body').test();
})();
// 출력 내용
// undefined undefined요약하면 이거.
저런 기능이 있었던가 하고 잠깐 정신이 아득해졌지만 뭐 어쩌겠어,
작업 중인 프로젝트 플러그인에서 사용중인 기능인데.

그래도 다행이 플러그인 내부에서 저 코드 블록을 호출하는 경우는 없고 외부에서만 사용한다.
플러그인을 뜯어 고치면 나중에 골 아픈 경우가 왕왕 생기니까 플러그인은 건들지 않고 우회 기능을 만들기로 한다.
$.fn.passThroughFn = function(options) {
    if (!(options instanceof Object)) {
        options = {
            selector: options,
        };
    }
    this.selector = options.selector;
    this.context = options.context || document;
    return this;
};공통 스트립트 파일에 해당 플러그인을 생성해서 넣었다.
.context 도 같이 removed 되었는데 딱히 사용하는 곳은 없지만 혹시나 하고 최소한의 방비책을 넣었다.
$.fn.test = function() {
    console.log(this.selector, this.context);
    return this;
};
(function() {
    $('body').passThroughFn('body').test();
})();
// 출력 내용
// body #document이제 구버전 플러그인을 사용하는 곳을 passThroughFn 을 통해 가도록 처리해 주면 된다.

'개발 > Front-End' 카테고리의 다른 글
| Vue CLI 를 통한 Vue 프로젝트 생성 (0) | 2022.06.22 | 
|---|---|
| 티스토리 작성 시간 숨기기 - 스킨 html 파일 치환자 변경 (0) | 2022.06.16 | 
| NPM 인스톨 에러 --force, --legacy-peer-deps (1) | 2022.05.24 | 
| 내부망에서 NPM 패키지 설치를 위한 방화벽 해제 (0) | 2022.05.19 | 
| jQuery 마이그레이션 - Deprecated, Removed (0) | 2022.05.17 |