λ‘œμΌ“πŸΎ
article thumbnail

 

λ¬΄ν•œ μŠ€ν¬λ‘€μ€ 이컀머슀 κ΄€λ ¨λœ μ›Ήμ΄λ‚˜ 앱을 μ‚¬μš©ν•˜λ©΄ μ‰½κ²Œ μ ‘ν•  수 μžˆλŠ” κΈ°λŠ₯μž…λ‹ˆλ‹€. 슀크둀의 μœ„μΉ˜κ°€ μ–΄λ– ν•œ 쑰건을 μΆ©μ‘±ν•˜κ²Œ 되면 μΆ”κ°€μ μœΌλ‘œ μƒν’ˆλ“€μ„ λΆˆλŸ¬μ˜΅λ‹ˆλ‹€. 

 

 

[JavaScript] λ¬΄ν•œ 슀크둀 μ‹œ μƒν’ˆ μœ„μΉ˜ μœ μ§€

λ¬΄ν•œ 슀크둀 κΈ°λŠ₯을 κ΅¬ν˜„ν•˜λŠ”λ° μžˆμ–΄ λ°˜λ“œμ‹œ λ³‘ν–‰λ˜μ–΄μ•Ό ν•  κΈ°λŠ₯이 μžˆμŠ΅λ‹ˆλ‹€. λ°”λ‘œ λ¬΄ν•œ 슀크둀둜 λ Œλ”λ§λœ μƒν’ˆμ„ λˆ„λ₯΄κ³  λ‹€μ‹œ [λ’€λ‘œκ°€κΈ°]λ₯Ό ν–ˆμ„ μ‹œ μ—¬μ „νžˆ κ·Έ μƒν’ˆμ˜ μœ„μΉ˜λ‘œ 와야 ν•œλ‹€λŠ” 것

kingofbackend.tistory.com

 

그럼 μ–΄λ–»κ²Œ κ΅¬ν˜„ν•˜λŠ”μ§€ λ°”λ‘œ μ•Œμ•„λ³΄κ² μŠ΅λ‹ˆλ‹€.

슀크둀이 νŠΉμ •μœ„μΉ˜λ‘œ κ°€λ©΄ μƒˆλ‘œμš΄ μƒν’ˆλ“€μ„ κ³„μ†ν•΄μ„œ λΆˆλŸ¬μ˜΅λ‹ˆλ‹€.

 

λ¬΄ν•œ 슀크둀 μ½”λ“œμž…λ‹ˆλ‹€.

var stopping = false;
var end = false;

$(window).scroll(function () {
        var cst = $(window).scrollTop();
        var csb = cst + $(window).height();

        var hooker = $('div').offset().top;
        if(hooker <= csb) {
            if(stopping === true || end === true) return false;

            var formData = $('form').serializeObject();
            sendAjaxPdtList(formData);//ajax κ΄€λ ¨ μ‚¬μš©μž ν•¨μˆ˜

            stopping = true;
        } else {
            stopping = false;
        }
    });

$().scrollTop()은 μ…€λ ‰ν„°μ˜ scrollTop μœ„μΉ˜λ₯Ό κ°€μ Έμ˜΅λ‹ˆλ‹€.

$().height()은 μ…€λ ‰ν„°μ˜ 높이λ₯Ό κ°€μ Έμ˜΅λ‹ˆλ‹€.

$().offset()은 μ…€λ ‰ν„°μ˜ μ’Œν‘œλ₯Ό κ°€μ Έμ˜΅λ‹ˆλ‹€.

leftλŠ” ν•„μš”μ—†μœΌλ‹ˆ top만 κ°€μ Έμ˜΅λ‹ˆλ‹€.

 

μ΄λ ‡κ²Œ μŠ€ν¬λ‘€μ— ν•„μš”ν•œ 값듀을 κ°€μ Έμ˜¨ λ’€ if(hooker <= csb) 처럼 νŠΉμ • 쑰건을 λ§Œμ‘±ν•˜λ©΄ ajaxλ₯Ό ν˜ΈμΆœν•˜μ—¬ μƒν’ˆλ“€μ„ μƒˆλ‘­κ²Œ κ°€μ Έμ˜΅λ‹ˆλ‹€. hookerλŠ” ajaxλ₯Ό ν˜ΈμΆœν•˜λŠ” 슀크둀의 κΈ°μ€€ μœ„μΉ˜κ°€ λ©λ‹ˆλ‹€.

 

이상 λ¬΄ν•œ μŠ€ν¬λ‘€μ— λŒ€ν•˜ μ•Œμ•„λ³΄μ•˜μŠ΅λ‹ˆλ‹€.

 

profile on loading

Loading...