ให้เรตสมาชิก: 3 / 5

ดาวใช้งานดาวใช้งานดาวใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งาน
 

บทที่ 18  Scripts
   JavaScript เป็นภาษาที่เป็น Script ที่อยู่ในเว็บไซต์ (ใช่ร่วมกับ HTML) เพื่อให้เว็บไซต์ของเราดูมีการเคลื่อนไหว สามารถตอบสนองผู้ใช้งานได้มากขึ้น โดยการใส่ Javascript ลงในโค๊ด HTML นั้นทำได้โดยใช้ แท็ก <script>  โดยจะแทรกอยู้ในแท็ก <head> และ แท็ก <body>
   ประโยชน์ของ javaScript
   เราจะใช้ JavaScript เมื่อต้องการทำให้ เวบเพจแสดงผลแบบเคลื่อนไหวได้ มีชีวิตชีวา ไม่แข็งทื่อ หรือใช้ในการสั่งให้ บราวเซอร์ทำงานตามที่เราต้องการ โดยงานนั้น อาจเกินความสามารถ ของภาษา HTML แต่ไม่ใช่งานที่ต้องติดต่อกับ Server นั่นเพราะ JavaScript เป็นภาษาที่ใช้ในการเขียนโปรแกรมทางฝั่ง client โดยมีบราวเซอร์เป็นตัวแปลภาษานั่นเอง ตัวอย่างของงาน ที่จะต้องใช้ภาษา JavaScript เช่น
    - สร้างเมนูที่สามารถตอบสนองต่อการเอา mouse ไปชี้ได้
    - สร้างเครื่องคิดเลข ปฏิทิน เกม ในเวบเพจ
    - เปิด, ปิด, เคลื่อนย้ายตำแหน่งของ window
    - ทำตัวอักษรวิ่งแบบต่างๆ
    - ตรวจสอบความถูกต้องของแบบฟอร์มที่ผู้ใช้กรอก ก่อนส่งข้อมูลไปยัง Server
    - และอื่นๆ อีกมากมายที่ไม่ต้องติดต่อกับ Server
ตัวอย่าง

<html>
<body>

<script>
document.write("Hello students!")
</script> 

</body>
</html>

ผลลัพธ์คือ

Tag ที่เกี่ยวข้อง
   1. แท็ก noscript ใช้ในการรองรับกรณีที่ผู้ใช้งานไม่อนุญาตให้รันสคริปส์ หรือ เว็บเบราว์เซอร์ไม่รองรับสคริปส์ เราสามารถใส่เนื้อหาในแท็ก noscript ได้เหมือนกับแท็ก body ซึ่งจะสามารถแสดงได้เหมือนไฟล์เอกสาร html ปกติ โดยเนื้อหาภายในแท็ก noscript จะแสดงก็ต่อเมื่อเว็บเบราว์เซอร์ไม่รองรับสคริปส์หรือไม่อนุญาตให้รันสคริปส์เท่านั้น
ตัวอย่าง

<html>
<body>

<script type="text/javascript">
document.write("สวัสดีนักเรียน")
</script>
<noscript>เว็บเบราว์เซอร์ของคุณไม่รองรับ JavaScript!</noscript>
 
</body>
</html>

ผลลัพธ์คือ

   2. ปุ่ม สำหรับลิงค์ไปหน้าอื่น
ตัวอย่าง

<html>
<body>

<p id="demo">
ภาษา HTML
</p>

<script>
function myFunction()
{
document.getElementById("demo").innerHTML="ภาษา HTML คือภาษาที่ใช้ในการเขียนเว็บ";
}
</script>

<button type="button" onclick="myFunction()">รายละเอียดเพิ่มเติม</button>

<script >
window.confirm("Are you sure you want to quit?")
</script>

</body>
</html>

ผลลัพธ์คือ


  3. เพิ่มเติมสไตล์ เช่น การสร้างปุ่ม สำหรับคลิกเลือกสีตัวอักษรที่ผู้ใช้งานต้องการให้แสดง

ตัวอย่าง

<html>
<body>

<p id="demo">
ไม่ชอบสีดำอยากเปลี่ยนเป็นแดง
</p>

<script>
function myFunction()
{
document.getElementById("demo").style.color="#ff0000";
}
</script>

<button type="button" onclick="myFunction()">คลิกตรงนี้</button>

</body>
</html>

 ผลลัพธ์คือ

   4. กล่องข้อความ (Message Box) เป็นส่วนที่ไว้สำหรับโต้ตอบกับผู้ใช้ แบ่งเป็น 3 แบบ คือ
           4.1 การเตือน (Alert)  ใช้สำหรับการขึ้นขอความเตือน ให้ผู้ใช้ระมัดระวัง หรือบอกกล่าวไปยังผู้ใช้ให้ทราบ  พิจารณาคำสั่งต่อไปนี้
ตัวอย่าง

<html>
<body>

<script >

window.alert("You can?t access to server!")

</script> 

</body>
</html>

ผลลัพธ์คือ

***ข้อความที่เขียนส่งให้เมธอด alert() เมื่อนำไปแสดงออกยัง ไดอะล็อกบ็อกซ์ จะปรากฏเป็นบรรทัดเดียว   ถ้าข้อความยาวมาก ไดอะล็อกบ็อกซ์ ที่ปรากฏ จะยาว ตามด้วย   หากผู้อ่านต้องการข้อความแยกกันหลายบรรทัด ให้ใช้ \n  แทรกระหว่างข้อความ
ตัวอย่าง

<html>
    body>

    <script language="JavaScript">
     alert("\n Hello   JavaScript  World \n Enjoy  with  JavaScript  now \n\n Click OK  to continue");
    </script>

    </body>
</html>

ผลลัพธ์คือ


   4.2 การยินยัน (Confirm)  เพื่อให้ผู้ใช้ยืนยันในกรณีที่ผู้ใช้อาจเผอเรอคลิกปุ่มโดยไม่ได้ตั้งใจ  เช่น ผู้ใช้กดปุ่มเพื่อลบข้อมูล หรือการออกจากโปรแกรม
ตัวอย่าง

<html>

<body>

<script >
window.confirm("Are you sure you want to quit?")
</script>

</body>
</html>

ผลลัพธ์คือ

   4.3 ตรวจสอบข้อมูล (Prompt)  เพื่อให้ผู้ใช้ป้อนข้อมูลก่อนเข้าไปยังระบบหรือเข้าหน้าเว็บ
ตัวอย่าง

<html>
<body>

<script >
window.prompt("please enter user name")
</script>

</body>
</html>

ผลลัพธ์คือ

   นอกจากนี้ยังมีตัวแปรที่เกิดจากการใช้ prompt ตัวอย่างเช่น

<html>
<body>

<script>

var y=window.prompt("please enter your name")

window.alert("Hello !   "  +y)

</script>

</body>
</html> 

***ตัวแปร y จะเก็บค่าที่ได้จากการป้อนของผู้ใช้  แล้วมาแสดงใน Message Box การเตือน ซึ่งมีข้อความ Hello !
ผลลัพธ์คือ

เมื่อผู้ใช้ป้อนชื่อแล้วกดปุ่ม OK จะเกิด Message Box ตามรูป



กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
หากจ่ายชำระค่าโทรศัพท์เกิน ควรบันทึกบัญชียังไง
โดย EyePornnipa ศ 16 ส.ค. 2019 12:10 pm บอร์ด ถาม - ตอบ ธุรกิจ กฏหมาย ภาษี บัญชี
1
23
ส 17 ส.ค. 2019 11:06 am โดย Amp_Audit
ยาหม่องสมุนไพรอินเดีย Himalaya Pain Balm 45 g กระปุกใหญ่ ใช้ดม ทาแก้วิงเวียนศีรษะ หอมสดชื่น ส่ง Kerry ถึงภายใน 1-3 วัน
โดย Tanadet ส 17 ส.ค. 2019 10:58 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
6
ส 17 ส.ค. 2019 10:58 am โดย Tanadet
สอบถาม การทำ web 2 ภาษา หน่อยครับ
โดย jirawoot ส 17 ส.ค. 2019 10:58 am บอร์ด Programming - C/C++ & java & Python
0
12
ส 17 ส.ค. 2019 10:58 am โดย jirawoot
งานประจำวันที่ 17 กรกฎาคม 2562
โดย jamepiyawat ส 17 ส.ค. 2019 10:16 am บอร์ด M084 - นายปิยวัช เชาว์วิมล
1
6
ส 17 ส.ค. 2019 11:23 am โดย mindphp
งานประจำวันที่ 17 สิงหาคม 2562
โดย jirawoot ส 17 ส.ค. 2019 10:02 am บอร์ด M090 - นายจิระวุฒิ อัครลิขิตกุล
2
5
ส 17 ส.ค. 2019 1:30 pm โดย jirawoot
งานประจำวันที่ 17 สิงหาคม 2562
โดย EyePornnipa ส 17 ส.ค. 2019 10:02 am บอร์ด M089 - นางสาวพรนิภา ราชธานี
3
22
ส 17 ส.ค. 2019 12:09 pm โดย thatsawan
Google Assistant เพิ่มฟีเจอร์ใหม่ สามารถเตือนความจำเราได้
โดย jamepiyawat ศ 16 ส.ค. 2019 6:41 pm บอร์ด Share Knowledge
0
14
ศ 16 ส.ค. 2019 6:41 pm โดย jamepiyawat
วิธีการดึกข้อมูลโพสต์โดยไม่ให้ มีการ Query Sql ที่มาเกิน ใน phpbb
โดย Ittichai_chupol ศ 16 ส.ค. 2019 6:08 pm บอร์ด PHP Knowledge
0
8
ศ 16 ส.ค. 2019 6:08 pm โดย Ittichai_chupol
พิสูจน์รักแท้ 3,790 ขั้น ที่… เขาวงพระจันทร์ จ.ลพบุรี (รอย้ายไปในบอร์ด Thailand Hotel)
โดย Patipat ศ 16 ส.ค. 2019 5:47 pm บอร์ด M088 - ปฏิภัทร สารธรรม
0
4
ศ 16 ส.ค. 2019 5:47 pm โดย Patipat
B - กด Save สร้างรายการ Product บนเมนู HR ไม่ได้
โดย EyePornnipa ศ 16 ส.ค. 2019 3:25 pm บอร์ด M.D.Soft Co.,Ltd. - Tester
1
6
ศ 16 ส.ค. 2019 3:47 pm โดย thatsawan
Q - ต้องการทำรายการจ่ายค่าใช้จ่ายจ่ายล่วงหน้า บนเมนู HR
โดย EyePornnipa ศ 16 ส.ค. 2019 3:00 pm บอร์ด M.D.Soft Co.,Ltd. - Tester
2
10
ศ 16 ส.ค. 2019 3:43 pm โดย EyePornnipa
G - เตรียมอัพเดทโปรแกรม เฟส 4
โดย thatsawan ศ 16 ส.ค. 2019 2:06 pm บอร์ด AZKing (Main)
0
3
ศ 16 ส.ค. 2019 2:06 pm โดย thatsawan
B - Import - Users ไม่ได้ [2019-08][003]
โดย tsukasaz ศ 16 ส.ค. 2019 11:28 am บอร์ด IIEC - Feedback Service System - Tester
0
2
ศ 16 ส.ค. 2019 11:28 am โดย tsukasaz
B - การคำนวณค่าไฟ Menu: Feedback Service > Electricity Comparison with Other Homes [2019-08][002]
โดย tsukasaz ศ 16 ส.ค. 2019 11:27 am บอร์ด IIEC - Feedback Service System - Tester
0
2
ศ 16 ส.ค. 2019 11:27 am โดย tsukasaz
Link ใน MDFiles มีไว้ทำอะไรครับ
โดย Patipat ศ 16 ส.ค. 2019 9:40 am บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS CRM
4
30
ศ 16 ส.ค. 2019 11:24 am โดย mindphp
กรณีออกใบกำกับภาษีผิด ควรดำเนินการยังไงค่ะ
โดย EyePornnipa ศ 16 ส.ค. 2019 9:40 am บอร์ด ถาม - ตอบ ธุรกิจ กฏหมาย ภาษี บัญชี
3
34
ส 17 ส.ค. 2019 10:53 am โดย Amp_Audit
งานประจำวันที่ 16 สิงหาคม 2562
โดย Patipat ศ 16 ส.ค. 2019 9:21 am บอร์ด M088 - ปฏิภัทร สารธรรม
1
3
ศ 16 ส.ค. 2019 7:41 pm โดย Patipat
R - tool_videotogif - โปรแกรมแปลงวีดีโอเป็นรูปภาพแบบ GIF
โดย jirawoot ศ 16 ส.ค. 2019 9:14 am บอร์ด M090 - นายจิระวุฒิ อัครลิขิตกุล
3
9
ศ 16 ส.ค. 2019 7:53 pm โดย jirawoot
งานประจำวันที่ 16 กรกฎาคม 2562
โดย jamepiyawat ศ 16 ส.ค. 2019 9:13 am บอร์ด M084 - นายปิยวัช เชาว์วิมล
1
3
ศ 16 ส.ค. 2019 7:41 pm โดย jamepiyawat
งานประจำวันที่ 16 สิงหาคม 2562
โดย EyePornnipa ศ 16 ส.ค. 2019 9:09 am บอร์ด M089 - นางสาวพรนิภา ราชธานี
1
15
ศ 16 ส.ค. 2019 6:37 pm โดย EyePornnipa