좌우형 슬라이드 갤러리 - 바닐라 스크립트 정보
좌우형 슬라이드 갤러리 - 바닐라 스크립트
관련링크
본문
이미지는 몇장이라도 상관없지만 가로 세로 길이가 똑 같은 이미지여야 합니다.
image_1 부터 원하는 갯수만큼 숫자를 붙여 나가면서 이미지 주소를 대입하면 자동으로 만들어집니다.
제이쿼리나 다른 라이브러리를 이용한 슬라이드 갤러리는 많지만 순정 바닐라 스크립트로 코드를 짜 논 걸 본적이 없어서 한번 만들어 보았습니다.
1. 전후진 버튼 클릭 후에는 자동넘기기시 전후진 방향 자동 감지.
2. 이미지가 제자리를 찾기 전에 버튼을 눌러도 반응이 없게 하는 "광분클릭 방지소스" 첨가
3. 가장 하단 <div style=width:960px> 의 가로는 퍼센트나 픽셀값을 바꾸면 바꾸는대로 알아서 이미지가 비율대로 리사이징 됩니다.
4. 옵션은 주석이나 스타일을 보면 금방 알 수 있습니다.
5. 기타 문제점이 보이면 차후 수정해 나갈게요.
--------------------
2021년 8월 15일 오후 9시 50분에 2가지 문제점을 수정하여 다시 올렸습니다.
1. 1픽셀씩 삑사리나는 오류 수정
2. 모바일 가로 세로 회전시 새로고침 없는 리사이징 구현
추천
11
11
댓글 32개
좋은자료 고맙습니다.
지난번에 js게시판 예제로 주신거 사용하고 있어요~
좋은 주말 보내세요~
지난번에 js게시판 예제로 주신거 사용하고 있어요~
좋은 주말 보내세요~

@rainbi 수정부분이 보입니다.ㅜㅠ

@rainbi 2가지 수정사항 보완했습니다. 새로 받아가세요.
@비타주리 확실한 AS
전 아무리 봐도 소스를 이해할 수 없지만 비타주리님이 계시니까...^^
기분좋은 대체휴일 아침입니다.
오늘도 행복하세요.
게시판 갤러리 최신글로도 활용할 수 있겠군요~
전 아무리 봐도 소스를 이해할 수 없지만 비타주리님이 계시니까...^^
기분좋은 대체휴일 아침입니다.
오늘도 행복하세요.
게시판 갤러리 최신글로도 활용할 수 있겠군요~

@rainbi 최신글이나 게시글의 리스트로도 가능하지요.
다만 내공이 좀 필요합니다. 개별이미지에 링크도 걸어야 하구요.
그것보다는 가로 세로 썸네일 이미지 크기가 게시물마다 다 틀려서 그걸 게시글을 작성할 때부터 염두에 두지 않으면 시각적으로는 별로입니다.
다만 내공이 좀 필요합니다. 개별이미지에 링크도 걸어야 하구요.
그것보다는 가로 세로 썸네일 이미지 크기가 게시물마다 다 틀려서 그걸 게시글을 작성할 때부터 염두에 두지 않으면 시각적으로는 별로입니다.
좋은자료 고맙습니다.
슬라이드중에 제일 좋은것같습니다.
슬라이드중에 제일 좋은것같습니다.


@파란하늘아래 2가지 수정사항 보완했습니다. 새로 받아가세요.

요즘 정말 좋은자료 많이 올려 주셔서 대단히 감사드리며, 매우 잘 사용하고 있습니다. 이제는 조금 덜 덥네요. 건강하세요.

@들레아빠
이런 움직임은 동일한 속도로 움직이는 등속운동이 아니라 처음에는 빨랐다가 서서히 느려지는 역가속 운동이 필요한데 이걸 구현하려면 극한값 접근이 필요해요.
이걸 다른 말로는 플래시 용어로 탄성스피드라고 합니다.
문제는 도착지 좌표 100 지점에 한없이 가까워진다 해도 그 수치는 대부분 100 이 되지 않는다는 것입니다. 99.999 등을 찍죠
탄성함수는 셋인터벌로 주는데 섬세하게 소스를 쓰려면 100지점에 이르면 셋인터벌을 중지시켜 클리어 해 주어야 컴에 부하가 덜 먹습니다.
하지만 99.999 로 수치가 나오니 눈에 보이기는 100 이지만 컴은 계속 클리어 되지 않고 탄성함수를 찍게 된다는 것이죠.
그래서 저는 반올림하여 100 이 되면 좌표가 100이 되면서 100이 되면 탄성함수를 멈추게 하는 소스를 썼는데요.
하지만 마이너스 좌표를 간과했어요.
마이너스는 -99.5 의 반올림 이 -100 이 아니라 -99 입니다.
그래서 0.5 를 걸쳐가는 부분에서 1픽셀의 삑사리가 나는 것이 보입니다. 죄표에 따라 좌우에 1픽셸 이동이 더해지거나 부족한 부분이 보이고 있네요.
결국 다음에는 100보다 0.5 작거나 또는 0.5 크거나 라는 조건문으로 바꾸어서 코드를 수정해야 할 것 같습니다.ㅜㅠ
이런 움직임은 동일한 속도로 움직이는 등속운동이 아니라 처음에는 빨랐다가 서서히 느려지는 역가속 운동이 필요한데 이걸 구현하려면 극한값 접근이 필요해요.
이걸 다른 말로는 플래시 용어로 탄성스피드라고 합니다.
문제는 도착지 좌표 100 지점에 한없이 가까워진다 해도 그 수치는 대부분 100 이 되지 않는다는 것입니다. 99.999 등을 찍죠
탄성함수는 셋인터벌로 주는데 섬세하게 소스를 쓰려면 100지점에 이르면 셋인터벌을 중지시켜 클리어 해 주어야 컴에 부하가 덜 먹습니다.
하지만 99.999 로 수치가 나오니 눈에 보이기는 100 이지만 컴은 계속 클리어 되지 않고 탄성함수를 찍게 된다는 것이죠.
그래서 저는 반올림하여 100 이 되면 좌표가 100이 되면서 100이 되면 탄성함수를 멈추게 하는 소스를 썼는데요.
하지만 마이너스 좌표를 간과했어요.
마이너스는 -99.5 의 반올림 이 -100 이 아니라 -99 입니다.
그래서 0.5 를 걸쳐가는 부분에서 1픽셀의 삑사리가 나는 것이 보입니다. 죄표에 따라 좌우에 1픽셸 이동이 더해지거나 부족한 부분이 보이고 있네요.
결국 다음에는 100보다 0.5 작거나 또는 0.5 크거나 라는 조건문으로 바꾸어서 코드를 수정해야 할 것 같습니다.ㅜㅠ


@들레아빠 2가지 수정사항 보완했습니다. 새로 받아가세요.

멋진 슬라이드 갤러리입니다

@man7777
수정해야할 부분이 두군데가 보여요.
수정해야할 부분이 두군데가 보여요.

@man7777 2가지 수정사항 보완했습니다. 새로 받아가세요.

@비타주리 감사합니다~~~

좋은자료감사

@eunoK 예 감사합니다

@eunoK 2가지 수정사항 보완했습니다. 새로 받아가세요.
멋지네요. 바로 테스트 해보겠습니다.
출처 밝히고 퍼가도 될까요?
출처 밝히고 퍼가도 될까요?

@호텔천사 예 그리 하시지요. 감사합니다.


깔끔하게 해결해 주셔서 대단히 감사합니다. 구~~우~~ㄷ 입니다.

@들레아빠 제 갤러리 소스는 제가 보아도 특별한 효과들이 꽤 있습니다. 이건 가장 기본적인 것이지요.
문제는 모두 액션 스크립트로 만든 것이라 몽땅 자바 스크립트로 치환해야 해요.ㅜㅠ
한 10개쯤 치환하고 게시글 첨부파일이나 아니면 인덱스 페이지에 링크 걸고 이미지 안에 텍스트 효과 줘서 사용할 수 있게 한 후 컨텐츠몰에 등록해 볼까 합니다.
소스도 바닐라라서 플러그인이 다 필요없거든요.
시간이 좀 걸릴 듯요,
문제는 모두 액션 스크립트로 만든 것이라 몽땅 자바 스크립트로 치환해야 해요.ㅜㅠ
한 10개쯤 치환하고 게시글 첨부파일이나 아니면 인덱스 페이지에 링크 걸고 이미지 안에 텍스트 효과 줘서 사용할 수 있게 한 후 컨텐츠몰에 등록해 볼까 합니다.
소스도 바닐라라서 플러그인이 다 필요없거든요.
시간이 좀 걸릴 듯요,

늘 고맙고 감사합니다.
잘 쓰겠습니다 ^^.
잘 쓰겠습니다 ^^.

@파란하늘아래 예 감사합니다
바닐라스크립트가 뭔지 검색해보니까 jquery와 같은 것을 사용하지 않고 순수하게 자바스크립트로만 코딩한 것이라고 나오는데, 정말로 자바스크립트로만 작성하셨네요.
어디에나 코드를 붙여넣기하고 이미지 경로만 정해주니까 잘 나오고 좋습니다.
늘 말씀드리지만 대단 하십니다.
새글에 슬라이드를 넣어보았습니다.
고맙습니다.
http://pws.co.kr/bbs/new.php
어디에나 코드를 붙여넣기하고 이미지 경로만 정해주니까 잘 나오고 좋습니다.
늘 말씀드리지만 대단 하십니다.
새글에 슬라이드를 넣어보았습니다.
고맙습니다.
http://pws.co.kr/bbs/new.php


@김철용
제게 세상에서 제일 재미있는 것이 스크립트 코딩이고 제일 재미없는 것이 css 퍼블리싱입니다.ㅋ
제게 세상에서 제일 재미있는 것이 스크립트 코딩이고 제일 재미없는 것이 css 퍼블리싱입니다.ㅋ
감사합니다.

@낙타1000 감사합니다
적용해 봤네요. 멋집니다.
근데, 이게 모바일에서 보니 손가락으로 넘기질 못하는거 같아요
좌우 버튼을 눌러야만 넘어가는데, 손가락으로 좌우 넘길수는 없을까요?
도와주세요,.
감사합니다.
근데, 이게 모바일에서 보니 손가락으로 넘기질 못하는거 같아요
좌우 버튼을 눌러야만 넘어가는데, 손가락으로 좌우 넘길수는 없을까요?
도와주세요,.
감사합니다.

@낭만강아지 도움드리지 못해 죄송합니다