COMING SOON 🚀

[jQuery] 실시간 검색어 순위 순서대로 보여주기

http://sir.co.kr/bbs/board.php?bo_table=tiptech&wr_id=3569

이 글을 보고 간단히 만들어봤습니다.


index.html

<!DOCTYPE html>
<html xmlns='http://www.w3.org/1999/xhtml'>
    <head>
        <title>Real-time Rank</title>
        <meta http-equiv="content-type" content="text/html; charset=utf-8" />
        <link href="stylesheet.css" media="screen" rel="stylesheet" type="text/css" />
        <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js" type="text/javascript"></script>
        <script src="application.js" type="text/javascript"></script>
        </head>
    <body>
        <div id="content">
            <dl id="rank-list">
                <dt>실시간 급상승 검색어</dt>
                <dd>
                    <ol>
                        <li><a href="#">1 순위</a></li>
                        <li><a href="#">2 순위</a></li>
                        <li><a href="#">3 순위</a></li>
                        <li><a href="#">4 순위</a></li>
                        <li><a href="#">5 순위</a></li>
                        <li><a href="#">6 순위</a></li>
                        <li><a href="#">7 순위</a></li>
                        <li><a href="#">8 순위</a></li>
                        <li><a href="#">9 순위</a></li>
                        <li><a href="#">10 순위</a></li>
                    </ol>
                </dd>
            </dl>
        </div>
    </body>
</html>


stylesheet.css

body {
    font-size: 12px;
    background: #FFF;
    color: #333;
    margin: 0;
}

#content {
    margin: 20px;
    padding: 10px;
    background: #393;
}

#rank-list a {
    color: #FFF;
    text-decoration: none;
}

#rank-list a:hover {
    text-decoration: underline;
}

#rank-list {
    overflow: hidden;
    width: 160px;
    height: 20px;
    margin: 0;
}

#rank-list dt {
    display: none;
}

#rank-list dd {
    position: relative;
    margin: 0;
}

#rank-list ol {
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
    padding: 0;
    list-style-type: none;
}

#rank-list li {
    height: 20px;
    line-height: 20px;
}


application.js

$(function() {
    var count = $('#rank-list li').length;
    var height = $('#rank-list li').height();

    function step(index) {
        $('#rank-list ol').delay(2000).animate({
            top: -height * index,
        }, 500, function() {
            step((index + 1) % count);
        });
    }

    step(1);
});

|

댓글 8개

올리고 보니 쓸데없는 재귀가 쓰였군요. 바보 같은 코드인데...

window.setInterval로 처리하시는 게 훨씬 안전할 것 같습니다.
생각해 보면 animate가 interval을 쓰기 때문에 그냥 저 코드 그대로 가도 되는군요.

혼자 뭐하는 거지 (...)
혹 네이버,다음,네이트 실시간 검색어 XML 필요하시면
http://bangabmoa.com/api/hitkeyword.php?type=xml
활용하세요.
upcount 말고 downcount가 있는지는 모르겠지만, 일단 upcount가 항상 있다는 가정 하에 적용해봤습니다.

[application.js]

$(function() {
function animateRankList() {
var count = $('#rank-list li').length;
var height = $('#rank-list li').height();

function step(index) {
$('#rank-list ol').delay(2000).animate({
top: -height * index,
}, 500, function() {
step((index + 1) % count);
});
}

step(1);
}

window.yqlCallback = function(data) {
$(data.query.results.channel.data.naver.item).each(function(index, item) {
var text = item.rank + ' - ' + item.keyword + ' [' + item.upcount + ']';
$('#rank-list li a').eq(index).text(text);
});

animateRankList();
}

$('#rank-list li a').text('');

var url = 'http://bangabmoa.com/api/hitkeyword.php?type=xml';
var yql = 'SELECT * FROM xml WHERE url="' + url + '"';

$.ajax({
url: 'http://query.yahooapis.com/v1/public/yql?q=' + yql +
'&format=json&callback=yqlCallback',
dataType: 'script'
});
});
댓글에선 들여쓰기가 하나도 적용 안 되네요.

http://www.google.co.kr/search?q=JavaScript+Beautifier

맘에 드시는 JavaScript Beautifier를 골라 잡아서 돌려주시면 들여쓰기가 깔끔히 적용된 코드를 보실 수 있을 겁니다.
http://jsbeautifier.org/

좋네요~ㅋ 감사합니다.
이거 여러 부분에서 유용하겠네요
오호~감사합니다
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 1,191
14년 전 조회 3,170
14년 전 조회 1,502
14년 전 조회 1,238
14년 전 조회 1,203
14년 전 조회 1,475
14년 전 조회 1,399
14년 전 조회 1,293
14년 전 조회 1,785
14년 전 조회 1,227
14년 전 조회 1,842
14년 전 조회 2,254
14년 전 조회 1,203
14년 전 조회 1,347
14년 전 조회 1,185
14년 전 조회 1,353
14년 전 조회 1,769
14년 전 조회 1,464
14년 전 조회 1,610
14년 전 조회 1,407
14년 전 조회 1,572
14년 전 조회 1,152
14년 전 조회 2,016
14년 전 조회 1,341
14년 전 조회 2,103
14년 전 조회 8,857
14년 전 조회 1,449
14년 전 조회 2,280
14년 전 조회 2,037
14년 전 조회 2,291
14년 전 조회 2,653
14년 전 조회 1,248
14년 전 조회 1,382
14년 전 조회 7,183
14년 전 조회 1,353
14년 전 조회 1,262
14년 전 조회 2,461
14년 전 조회 1,354
14년 전 조회 1,331
14년 전 조회 2,818
14년 전 조회 1,426
14년 전 조회 4,330
14년 전 조회 4,455
14년 전 조회 1,804
14년 전 조회 1,380
14년 전 조회 2,029
14년 전 조회 1,306
14년 전 조회 1,606
14년 전 조회 1,208
14년 전 조회 8,099
14년 전 조회 1,740
14년 전 조회 1,140
14년 전 조회 1,305
14년 전 조회 2,001
14년 전 조회 1,435
14년 전 조회 1,303
14년 전 조회 1,391
14년 전 조회 1,306
14년 전 조회 1,169
14년 전 조회 1,280
14년 전 조회 1,285
14년 전 조회 1,288
14년 전 조회 1,322
14년 전 조회 1,603
14년 전 조회 1,591
14년 전 조회 1,839
14년 전 조회 1,470
14년 전 조회 1,392
14년 전 조회 1,290
14년 전 조회 1,228
14년 전 조회 1,248
14년 전 조회 1,423
14년 전 조회 2,644
14년 전 조회 1,304
14년 전 조회 1,623
14년 전 조회 2,772
14년 전 조회 1,897
14년 전 조회 1,636
14년 전 조회 5,382
14년 전 조회 2,585
14년 전 조회 1,418
14년 전 조회 1,335
14년 전 조회 1,278
14년 전 조회 1,171
14년 전 조회 2,465
14년 전 조회 3,777
14년 전 조회 1,257
14년 전 조회 1,454
14년 전 조회 2,447
14년 전 조회 1,291
14년 전 조회 1,939
14년 전 조회 2,270
14년 전 조회 1.1만
14년 전 조회 1,812
14년 전 조회 1,622
14년 전 조회 2,329
14년 전 조회 2,383
14년 전 조회 1,551
14년 전 조회 1,644
14년 전 조회 1,455