COMING SOON 🚀

jquery loaded 커스텀 함수

· 11개월 전 · 1240

$("div.section").ready()같은 함수가 필요해서 만들었습니다. 비동기로 dom에 삽입될때도 작동합니다.

[code]

$.fn.loaded = function(node_selector,callback_func,option){
    var loaded = [];
    // 감시 대상 요소 선택
    $(this).each(function (i,e) {

        var $target = $(e);
        var targetNode = $target[0];
        var added = [];

        if (!node_selector instanceof jQuery){
            node_selector = $(node_selector);
        }

        var callback_excute = function (index,elem) {
            // if(elem.weaver_loaded==true){
            //     return false;
            // }
            if(loaded.includes(elem)){
                return false;
            }
            loaded.push(elem);
            // elem.weaver_loaded=true;
            callback_func.call(elem,index,elem);
        }

        $(node_selector,$target).each(function (i,e) {

            callback_excute(i,e)
        })

        var config = { childList: true, subtree: true };


        var observer = new MutationObserver(function(mutationsList, observer) {
            for(var mutation of mutationsList) {

                if (mutation.type === 'childList') {

                    $.each(mutation.addedNodes,function (j,k){
                        var $node ;

                        if($(k).is(node_selector)){
                            $node = $(k);

                            callback_excute(j,$node[0])

                        }else{
                            $(node_selector,$(k)).each(function (x,y) {

                                callback_excute(x,y)
                            });
                        }

                    })


                }
            }
        });
        observer.observe(targetNode, config);
    })
};

 

// 사용법

$("div.section").loaded(function(i,e){

    $(this).html('test');

}}

[/code]

|
댓글을 작성하시려면 로그인이 필요합니다.

개발자팁

개발과 관련된 유용한 정보를 공유하세요. 질문은 QA에서 해주시기 바랍니다.

+
분류 제목 글쓴이 날짜 조회
JavaScript 2개월 전 조회 400
MySQL 3개월 전 조회 529
PHP 4개월 전 조회 789
PHP 4개월 전 조회 618
PHP 4개월 전 조회 572
기타 7개월 전 조회 818
PHP 8개월 전 조회 1,456
MySQL 9개월 전 조회 1,105
웹서버 11개월 전 조회 1,278
1년 전 조회 1,655
1년 전 조회 1,622
1년 전 조회 1,473
1년 전 조회 1,295
1년 전 조회 1,463
11개월 전 조회 1,241
JavaScript 11개월 전 조회 1,463
웹서버 11개월 전 조회 1,494
JavaScript 1년 전 조회 1,273
기타 1년 전 조회 1,748
기타 1년 전 조회 934
JavaScript 1년 전 조회 1,398
기타 1년 전 조회 1,157
JavaScript 1년 전 조회 1,124
1년 전 조회 1,610
기타 1년 전 조회 1,133
jQuery 1년 전 조회 852
jQuery 1년 전 조회 1,184
기타 1년 전 조회 1,260
MySQL 1년 전 조회 1,322
기타 1년 전 조회 1,503