jquery loaded 커스텀 함수

· 10개월 전 · 1066

$("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 1개월 전 조회 240
MySQL 2개월 전 조회 334
PHP 3개월 전 조회 584
PHP 3개월 전 조회 436
PHP 3개월 전 조회 400
기타 6개월 전 조회 641
PHP 7개월 전 조회 1,279
MySQL 7개월 전 조회 898
웹서버 10개월 전 조회 1,113
1년 전 조회 1,456
1년 전 조회 1,449
12개월 전 조회 1,274
11개월 전 조회 1,114
10개월 전 조회 1,299
10개월 전 조회 1,067
JavaScript 10개월 전 조회 1,285
웹서버 10개월 전 조회 1,314
JavaScript 11개월 전 조회 1,099
기타 12개월 전 조회 1,523
기타 1년 전 조회 763
JavaScript 1년 전 조회 1,226
기타 1년 전 조회 986
JavaScript 1년 전 조회 943
1년 전 조회 1,457
기타 1년 전 조회 1,003
jQuery 1년 전 조회 714
jQuery 1년 전 조회 999
기타 1년 전 조회 1,059
MySQL 1년 전 조회 1,157
기타 1년 전 조회 1,312
🐛 버그신고