![]() |
|
|
#1 | ||
|
HotDog
เป็นสมาชิกเมื่อ: Jan 2009
ที่อยู่: Bangkok
โพส: 167
|
ขอบคุณบทความดีดีจาก
divland.com เมื่อเราเขียน CSS มาจนถึงระดับหนึ่งแล้ว เราจะพบว่า CSS ก็คือการตกแต่งหน้าตาเว็บไซต์ ให้สวยงาม เป็นการแสดงผลเท่านั้น เหมือน HTML ไม่สามารถโต้ตอบกับผู้ใช้ได้เหมือน php asp เราจะทำอย่างไรหากต้องการให้ หน้าตาเว็บไซต์ ถูกกำหนดโดยผู้ใช้ เลือกสีกรอบได้ คลิกแล้วเปลี่ยนกรอบได้ ฟังดูน่าสนใจใช่มั้ยล่ะครับ ในกรณีนี้ เราจะใช้ จาวาสคริป เข้ามาช่วยควบคุม ลองมาดูตัวอย่าง การทำ Toggle อย่างง่ายกันครับ เริ่มต้นเรามี HTML ดังนี้ HTML Code:
<h2>Menu</h2> <div id="abc" style="display:none";> submenu submenu </div> HTML Code:
<script type="text/javascript"> function toggle(obj) { var el = document.getElementById(obj); if ( el.style.display != ‘none’ ) { el.style.display = ‘none’; } else { el.style.display = ”; } } </script> บรรทัดที่ 1 เป็นการประกาศว่าเราจะใช้ จาวาสคริป แล้ว บรรทัดที่ 2 ประกาศฟังชั่น ชื่อ toggle รับค่า1 ค่า ให้ชื่อ obj (object) ละกัน บรรทัดที่ 3 ประกาศตัวแปร 1 ตัว ชื่อ el ย่อมาจาก element ให้เท่ากับ document.getElementById(obj) แปลว่า ไปที่เอกสาร แล้วไป get ค่า โดยมองจาก id ที่ชื่อ (obj) <-- อันนี้เด๋วจะส่ง abc ใส่เข้ามา บรรทัดถัดมา เป็นเงื่อนไข ถ้า el มี style และมี display ไม่เท่ากับ none ก็ให้ ใส่ื none เข้าไป ถ้ามี none อยู่แล้วก็ให้ display เป็น ค่าว่างเปล่าๆ เราสามารถใช้ style. แล้วตามด้วย property ของ css ได้เลย เช่น el.style.background , el.style.font-size เพื่อกำหนด css จากนั้น เพิ่มลิ้งเพื่อเรียกใช้ฟังชั่นที่ HTML ดังนี้ HTML Code:
<h2><a href="#" onclick="toggle(’abc’);return false">Menu</a></h2> <div id="abc" style="display:none";> submenu submenu </div> เมื่อกด ครั้งแรก เราส่งค่า abc เข้าไปที่มี display:none อยู่แล้ว javascript ก็จะเขียน style ให้ใหม่เป็น display:ค่าว่างๆ พอกดครั้งที่สอง เราส่งค่าไปอีกครั้ง คราวนี้เป็นค่า display เปล่าๆ ไม่มี none ก็จะเข้าเงื่อนไข แรก javascript ก็จะเขียน style ให้ใหม่เป็น display:none ส่วน return:false ใส่ไว้ เมื่อกดลิ้งค์ที่มี ค่าเป็น # หน้าเว็บจะไม่เด้งขึ้นไปบนสุด เป็นเทคนิคเล็กๆน้อยๆ ตัวอย่างนี้อาจจะงงไปสักหน่อย สำหรับผู้ที่ไม่มีพื้นฐาน จาวาสคริปเลย ลองศึกษา จาวาสคริปสักหน่อย แล้วจะเข้าใจครับ สามารถ นำไปประยุกต์ใช้ได้อีกหลายอย่างเช่น ทำลิ้งค์ให้ผู้ใช้เลือกขนาดอักษรในหน้าเว็บได้ หรือ ทำลิ้งค์ให้ผู้ใช้ เลือกสี แบ็คกราวน์ทั้งหมดในหน้าเว็บได้ ตัวอย่างการทำงานครับ http://www.divland.com/blog/wp-conte...08/toggle.html
__________________
Ethaidesign.com The Communities Graphic & Developer free forums.![]() |
||
|
|
|
|
|
#2 | ||
|
สมาชิกบอร์ด
เป็นสมาชิกเมื่อ: Aug 2009
โพส: 39
|
แจ่มครับ แต่ถ้าใช้ jquery ทำจะง่ายกว่านี้ อิอิ
__________________
Web Hosting 10GB ขึ้นไป ไม่จำกัดแบทวิท เริ่มต้นเพียง 499บาท/ปี จดโดเมน 350 บาท/ปี จดพร้อมเช่าโฮสต์ 299 บาท/ปี นึกถึง Hostคุณภาพบริการชั้นหนึ่ง นึกถึง HostNeverDie.com |
||
|
|
|
![]() |
| คำค้น (Tags) |
| javascript กับ css, เขียน javascript |
| Thread Tools | |
|
|