ทำ Back to top (แบล็คทูท็อป)เลื่อนลงมาๆถึงแสดง

HTML Basic
สำหรับนักพัฒนาเว็บไซต์มือใหม่ HTML , CSS และการใช้ Tools ต่างๆ ในการพัฒนาเว็บไซต์

Moderator: mindphp

ภาพประจำตัวสมาชิก
pond
PHP Super Hero Member
PHP Super Hero Member
โพสต์: 570
ลงทะเบียนเมื่อ: 25/05/2016 9:44 am

ทำ Back to top (แบล็คทูท็อป)เลื่อนลงมาๆถึงแสดง

โพสต์ที่ยังไม่ได้อ่าน โดย pond »

ซึ่งหลายคนคงเคยเข้าเว็บไซต์แล้วหน้านั้นๆหรือบทความนั้นๆมีเนื้อหาหน้าเว็บไซต์ที่ค่อนข้างยาวแล้วเมื่อท่านต้องการจะเลื่อนขึ้นข้างบนละก็จะต้องเสียเวลาในการเลื่อนเอง ซึ่งปัญหานี้เหล่านี้จะหมดไปถ้าเว็บไซต์ของท่านนั้นได้สร้าง Back to top เอาไว้ให้

ซึ่งวันนี้เองผมมี Code Back to top (แบล็คทูท็อป) ดีๆมาฝากกันซึ่งจะไม่แสดงเมื่อท่านอยุ่ส่วนบนของเว็บไซต์แต่จะปรากฏเมื่อเลื่อนลงข้างล่างมาเริ่มกันเลยดีกว่า
ก่อนอื่นเลยให้ท่านไปใส่ id ให้ body

โค้ด: เลือกทั้งหมด

<body id="top">
ตามด้วยส่วนที่จะทำเป็นปุ่มกด Back to top ซึ่ง class ที่อยู่ใน span คือส่วนที่แสดงลูกศรถ้าท่านไหนใช้ Bootstrap สามารถใช้ class ตามนี้ได้เลย glyphicon glyphicon-arrow-up pondtoptoptop

โค้ด: เลือกทั้งหมด

<p id="back-top">
    <a href="#top">
        <span style="color: white;" class="glyphicon glyphicon-arrow-up pondtoptoptop"></span>
        Back to Top
    </a>
</p>
จะได้แบบนี้
Workspace 1_235.png
Workspace 1_235.png (11.53 KiB) Viewed 4408 times
code Css

โค้ด: เลือกทั้งหมด

#back-top {
    position: fixed;
    bottom: 15px;
    /*margin-left: -150px;*/
    right: 20px;
}

#back-top a {
    /*width: 60px;*/
    display: block;
    text-align: center;
    font: 11px/100% Arial, Helvetica, sans-serif;
    /*text-transform: uppercase;*/
    text-decoration: none;
    color: black;
    font-weight:bold;
    opacity: 0.9;

    /* transition */
    -webkit-transition: 1s;
    -moz-transition: 1s;
    transition: 1s;
}
#back-top a:hover {
    color: #000;
}

/* arrow icon (span tag) */
#back-top span {
    width: 60px;
    height: 60px;
    display: block;
    margin-bottom: 7px;
    background: #ddd url(up-arrow.png) no-repeat center center;

    /* rounded corners */
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    border-radius: 15px;

    /* transition */
    -webkit-transition: 1s;
    -moz-transition: 1s;
    transition: 1s;
}
#back-top a:hover span {
    background-color: #005419;
}
ส่วนสุดท้ายให้นำ javascript ไปไว้ในส่วนข้างล่างสุด ตัวเลข 150 หมายถึงเลื่อนลงมาจากข้างบนเท่าไหร่ถึงจะแสดง Back to top ส่วนตัวเลข 1100 คือระยะเวลาในขึ้นสู่ข้างยิ่งตัวเลขมากยิ่งนานขึ้น โดย 1000 ต่อหนึ่งวินาที

โค้ด: เลือกทั้งหมด

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.3/jquery.min.js"></script>
<script>
$(document).ready(function(){
	// hide #back-top first
	$("#back-top").hide();
	// fade in #back-top
	$(function () {
		$(window).scroll(function () {
			if ($(this).scrollTop() > 150) {
				$('#back-top').fadeIn();
			} else {
				$('#back-top').fadeOut();
			}
		});
		// scroll body to 0px on click
		$('#back-top a').click(function () {
			$('body,html').animate({
				scrollTop: 0
			}, 1100);
			return false;
		});
	});
});
</script>
Stickgaron
PHP Newbie
PHP Newbie
โพสต์: 1
ลงทะเบียนเมื่อ: 04/04/2017 3:27 pm

Re: ทำ Back to top (แบล็คทูท็อป)เลื่อนลงมาๆถึงแสดง

โพสต์ที่ยังไม่ได้อ่าน โดย Stickgaron »

เดี๋ยวผมจะไปลองทำดูแต่ไม่รู้ว่าจะยังไง
ตอบกลับโพส
  • Similar Topics
    ตอบกลับ
    แสดง
    โพสต์ล่าสุด

ผู้ใช้งานขณะนี้

สมาชิกกำลังดูบอร์ดนี้: ไม่มีสมาชิกใหม่ และบุคลทั่วไป 38