스아이

반응형페이징!

반응형웹만들때 페이징때문에 고민하셨죠? 간편하게 제가 하나만들었습니다ㅎ

 

[code]

<script type="text/javascript" src="//code.jquery.com/jquery-1.11.0.js"></script> 

<style type="text/css">

.paging{color:#555;padding:0;}

.paging li{list-style:none;}

.paging li{line-height:25px; cursor:default; text-align:center; width:25px; height:25px; display:inline-block; font-size: 12px; font-weight:bold; color:#333;}

.paging .pg:hover{cursor:pointer; text-decoration: underline}

.paging .current{color:#FF3636; cursor:default !important; text-decoration:none !important;}

.first, .pre, .next, .last{color:#888 !important;}

.first, .last{letter-spacing:-3px;}

.active{color:#333 !important; cursor:pointer !important;}

</style>

 

<script type="text/javascript">

 

window.onload = function() {

var n = 0,

    c  = 35 , // 전체페이지(35페이지)

    w = 27 , //페이지표시 1개의 가로사이즈값

    current = 1; // 현재페이지(1페이지)

 

/* 페이지클릭시 */

$(document).delegate('.pg','click',function(e){

current = parseInt($(this).text());

$('.pg').removeClass('current');$(this).addClass('current'); // 페이지 클릭시 추가되는 클래스(current)

});

 

/* 맨앞, 앞, 뒤, 맨뒤 버튼 클릭시 */

$(document).delegate('.first, .pre, .next, .last','click',function(e){

var x = Math.floor((parseInt($('.paging').css('width'))-w*4)/w);

if(x > 10){x=10;}

if(n >= 1){

if($(this).is('.first')){current=1;paging();}

if($(this).is('.pre')){current=n-x+1;paging();}

if(c > n+x){

if($(this).is('.next')){current=n+x+1;paging();}

if($(this).is('.last')){current=c;paging();}

}

});

    

/* 맨앞, 앞, 뒤, 맨뒤 버튼 클릭시 */

function paging(){

var page='<li class="first"><<</li><li class="pre"><</li>';

var x = Math.floor((parseInt($('.paging').css('width'))-w*4)/w);

if(x > 10){x=10;}

n = Math.floor(current/x);

if(n == current/x){n = n*x-x;}else{n = n*x}

for(var i=1; i <= x; i++ ){

if(current == i+n){

page += '<li class="pg current">'+(i+n)+'</li>';

}else{

page += '<li class="pg">'+(i+n)+'</li>';}

if(i == x || i == 10 || i+n == c){$('.paging').html(page+'<li class="next">></li><li class="last">>></li>');

if(n > 1){$('.first, .pre').addClass('active');}  // 맨앞, 앞 활성화시 추가되는 클래스(active)

if(c > n+x){$('.next, .last').addClass('active');}  // 뒤, 맨뒤 버튼 활성화시 추가되는 클래스(active)

break}}

}

 

paging() //웹페이지 불러올시 반응형페이징 함수 작동

 

window.onresize = function(){paging()}  //브라우저 사이즈 조절시 반응형페이징 함수 작동

}

 

</script>

 

<ul class="paging"></ul> <!-- 반응형페이징을 불러올 위치 -->

 

[/code]

군인신분으로 사이버지식정보방에서 만든거라 보안상 파일업로드가 안되므로 글로 올리는점 양해바랍니다.

 

http://sir.co.kr/bbs/board.php?bo_table=cm_free&wr_id=1113337

 

|

댓글 14개

그누보드에 연동할시 게시판스킨에서 <?php echo $write_pages; ?>와 기존 페이징 관련css를 모조리 지우신후에 원하는 위치에 저소스를 삽입하고

c = 35 , // 전체페이지(35페이지) 이부분을

c = <?php echo $total_page?> , 로 수정해주시고

current = 1; // 현재페이지(1페이지) 이부분을

current = <?php echo $page ?>; 로 수정해주시면됩니다.

디자인은 알아서^^;
복무중에 귀한자료를 ^^.. 감사합니다. 그리고 남은 군복무 잘 마무리 하세요 ~
예^^...감사합니다;
그누보드에서 페이지에 링크거는법을깜빡했네요. 이걸추가시키면됩니다^^;
25번줄과 26번줄 구문 사이에 이스크립트를 추가시키면됩니다.

[code]
$(location).attr('href',<?php echo g5_bbs_url ?> + '/board.php?bo_table=' + <?php echo $bo_table ?> + '&page=' + current );
[/code]
우와...좋은 소스 고마워요. 잘 쓸게요.
근데, 대체 뭘 공부하면 이런 걸 짤 수 있죠? ㅎ
그냥...독학했습니다^^;
외국사이트돌아다니면서 소스도 한번씩 파헤쳐보고...ㅎ;
제가 반응형웹을 처음 접하게된게 아마 2013년때쯤이었을껍니다.. 그러다가 css로 반응형웹을 짜는기술도 있공...자유롭게 하는방법에선 자바스크립트가 짱이더라고요ㅎ;
오호, 3년만에 이런 성취를....대단하십니다. ^^
거기에 20개월 가까이 지금 군대에있습니다...ㅎ;
군생활 제대로 하셨네요. ㅎㅎ
적용해야겟네요 ㅎ
얼마든지요^^ㅎ;
오~좋은 것 같아요~잘 쓰겠습니다~
잘 쓰겠습니다. 군인이신데 바쁜 와중에도 좋은 자료를 올려주셨네요.
28일에 전역했어요^^ㅋ;
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
10년 전 조회 833
10년 전 조회 1,397
10년 전 조회 1,028
10년 전 조회 598
10년 전 조회 601
10년 전 조회 844
10년 전 조회 1,364
10년 전 조회 809
10년 전 조회 1,050
10년 전 조회 911
10년 전 조회 668
10년 전 조회 981
10년 전 조회 498
10년 전 조회 726
10년 전 조회 640
10년 전 조회 958
10년 전 조회 1,151
10년 전 조회 1,071
10년 전 조회 768
10년 전 조회 1,087
10년 전 조회 882
10년 전 조회 642
10년 전 조회 1,243
10년 전 조회 714
10년 전 조회 996
10년 전 조회 670
10년 전 조회 518
10년 전 조회 1,905
10년 전 조회 994
10년 전 조회 1,014
10년 전 조회 795
10년 전 조회 1,081
10년 전 조회 939
10년 전 조회 676
10년 전 조회 1,153
10년 전 조회 1,585
10년 전 조회 991
10년 전 조회 877
10년 전 조회 905
10년 전 조회 815
10년 전 조회 1,512
10년 전 조회 1,414
10년 전 조회 466
10년 전 조회 855
10년 전 조회 439
10년 전 조회 802
10년 전 조회 2,282
10년 전 조회 817
10년 전 조회 2,862
10년 전 조회 1,512
10년 전 조회 1,132
10년 전 조회 473
10년 전 조회 827
10년 전 조회 1,115
10년 전 조회 1,539
10년 전 조회 2,897
10년 전 조회 1,679
10년 전 조회 1,843
10년 전 조회 2,317
10년 전 조회 3,898
10년 전 조회 1,515
10년 전 조회 665
10년 전 조회 2,358
10년 전 조회 801
10년 전 조회 1,025
10년 전 조회 1,788
10년 전 조회 689
10년 전 조회 709
10년 전 조회 3,018
10년 전 조회 710
10년 전 조회 587
10년 전 조회 554
10년 전 조회 479
10년 전 조회 1,019
10년 전 조회 736
10년 전 조회 623
10년 전 조회 723
10년 전 조회 1,230
10년 전 조회 2,071
10년 전 조회 1,136
10년 전 조회 1,404
10년 전 조회 1,900
10년 전 조회 1,312
10년 전 조회 1,114
10년 전 조회 1,043
10년 전 조회 3,919
10년 전 조회 699
10년 전 조회 1,023
10년 전 조회 1,629
10년 전 조회 1,067
10년 전 조회 2,780
10년 전 조회 1,005
10년 전 조회 936
10년 전 조회 1,020
10년 전 조회 4,591
10년 전 조회 891
10년 전 조회 2,409
10년 전 조회 1,726
10년 전 조회 2,364
10년 전 조회 1,941
🐛 버그신고