[อัพเดต]
เจอปัญหาแล้วครับ หลังจากเตรียมไฟล์เพื่อจะอัพโหลดให้ช่วยดู ผมเข้าใจปัญหาถูก ที่ว่ามันอยู่ตรงตำแหน่งการวาง tag script แต่เข้าใจไม่ถูกจุด
สิ่งที่ได้รู้คือ ถ้าวาง
<script src="script.js"></script>
ก่อน
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
มันจะไม่ทำงาน คงจำไปอีกนาน คิดเอาเองว่ามันเป็น javascript มันก็คงจะเหมือนๆ กัน
ถ้าจะใช้ jquery ต้องแนบไฟล์ jquery.min.js ไปด้วยเสมอใช่ไหมครับ
[ข้อความเดิม]
ณ ที่ตรงนี้คือมือใหม่หัดเล่น
index.html
<html>
<header>
<script src="script.js"></script>
</header>
<body>
</body>
</html>
เคยจำได้ว่า ให้วางไว้ในส่วน Header
ณ ตอนนี้ ถ้าทำแบบนั้น script จะไม่ทำงานเลยครับ เหมือนมันไม่โหลด แต่พอเอามาวางไว้ในส่วนของ body กลับทำงานเป็นปรกติ
แต่ถ้าเป็น code เพียวๆ นำมาวาง header ก็ยังทำงานได้อยู่ หรือว่ามันจะเกี่ยวกับตัวนี้
$(document).ready(function(){
});
ลอง Google แล้วครับ แต่ก็ยังไม่เข้าใจ
on
ขอดูตัวเนื้อหาด้วยได้มั้ยครับ
hisoft Thu, 22/06/2017 - 22:56
ขอดูตัวเนื้อหาด้วยได้มั้ยครับ?
เอามาจากตรงนี้เลยครับ
Elysium Thu, 22/06/2017 - 23:08
In reply to ขอดูตัวเนื้อหาด้วยได้มั้ยครับ by hisoft
เอามาจากตรงนี้เลยครับ
index.html ถ้าเป็นตามนี้ Code จะทำงานปรกติครับ แต่พอเอามาวางตรง header มันกลับไม่ทำงาน เหมือนไม่ถูกเรียก
ไฟล์ script.js
เอ
hisoft Fri, 23/06/2017 - 00:29
In reply to เอามาจากตรงนี้เลยครับ by Elysium
เอ ตามลิงก์ที่ให้มาสคริปต์มันก็อยู่ใน header นี่ครับ?
แล้วผมลองย้ายจาก header ลงไปใน body มันก็ยังทำงานได้เหมือนกัน
ทุกอย่างปรกติครับ
Elysium Fri, 23/06/2017 - 12:45
In reply to เอ by hisoft
ทุกอย่างปรกติครับ ปัญหามันอยู่ที่ตำแหน่งการวาง
ลองบน Win 8.1 IE11, Chrome กับ Win10 Edge ปัญหาก็มีตามที่บอกไว้ เอาโค้ดออกจากส่วนของ ready มาวางข้างนอก (ไม่มี ready มาครอบ) ก็ยังไม่ทำงานเหมือนกัน
ไม่แน่ใจว่าแก้ได้หรือยัง
hisoft Fri, 23/06/2017 - 21:15
In reply to ทุกอย่างปรกติครับ by Elysium
ไม่แน่ใจว่าแก้ได้หรือยัง แต่ถ้ายังไงขอชุดตัวอย่างแบบที่ได้กับไม่ได้เต็มๆ มาดูกันดีไหมครับ
กับ
mix5003 Fri, 23/06/2017 - 12:55
In reply to เอามาจากตรงนี้เลยครับ by Elysium
head กับ header มันคนละ tag กันนะครับ
ตำแหน่งการวาง script ได้วางหลัง jquery รึเปล่าครับ
เกี๋ยวครับ เพราะ $(document)
osmiumwo1f Thu, 22/06/2017 - 23:11
เกี๋ยวครับ เพราะ $(document).ready(function(){}); จะมองว่าตัว html มันโหลดเสร็จยัง ถ้ายังไม่เสร็จ js จะยังไม่ทำอะไรที่อยู่ข้างในนั้นครับ
เท่าที่ดู
waroonh Fri, 23/06/2017 - 10:06
เท่าที่ดู ไม่มีอะไรผิดเลยครับควรจะ run ได้เลย
รวมถึง ตัว code ที่โพสมาเป็นตัวอย่างด้วยครับ แต่ที่สังเกตเห็นคือ
ref จาก Google CDN
src=https://ajax.googleapis.com
เครื่องไม่ต่อออก internet อยู่ไม่ทำงานแน่นอน
ถ้าต่อ net อยุ่ browser อาจจะ disable
การ run script อยู่ เพราะ run บนเครื่องโดยตรง ครับ
$("button").click(function(){
i3i4i5 Fri, 23/06/2017 - 11:39
$("button").click(function(){
$("p").toggle();
});
ถ้าวางไว้ใน header หรือไว้ด้านบน tag button สคริปจะทำงานก่อน DOM (button นั่นแหละ) จะโหลดเสร็จ ทำให้ใช้งานไม่ได้
ส่วนถ้าครอบด้วย $(document).ready(function(){}); จะทำให้สคริปทำงานหลัง DOM โหลดเสร็จ
คือจำไว้นะครับว่า ถ้าจะเราใช้
7elven Tue, 04/07/2017 - 02:12
คือจำไว้นะครับว่า ถ้าจะเราใช้ lib ตัวไหนเราก็ต้องโหลด lib ตัวนั้นก่อน
ในที่นี้คือ jquery ก็ต้องวางไว้ก่อนที่เราจะเรียก script ของเรา
และผมขอแนะนำอย่างนึงเวลาโหลดหน้าเว็บ ถ้า script ของเรามีการจัดการ element ด้วย
ให้นำ script ไปวางไว้ก่อน แบบนี้แทน เพื่อที่จะได้แน่ใจว่า html ทั้งหมดถูกโหลดแล้ว
มันดีกว่าต้องใช้ on ready แน่นอนครับ และปัจจุบันก็แนะนำให้ทำแบบนี้ ตรง head เอาไว้ใส่พวก lib ก็พอ
ปล.มีความรู้สึกเดจาวูอย่างบอกไม่ถูก ไม่ได้ว่า จขกท นะครับ แต่ผมรู้สึกจริงๆ
คงจำได้ขึ้นใจละครับทีนี้
Elysium Tue, 04/07/2017 - 09:52
In reply to คือจำไว้นะครับว่า ถ้าจะเราใช้ by 7elven
คงจำได้ขึ้นใจละครับทีนี้ (ถ้าจะให้แก้ตัว คงต้องบอกว่าปรกติจะชินแต่กับ JavaScript เพียวๆ ละครับ ไม่ใช่โปรแกรมเมอร์นะ เวลาแต่ง Blogger มันเจอบ่อยๆ สามารถสุดได้แค่นี้ละครับ ^_^)
หมายถึงวางไว้ก่อนปิดแท็ก body ใช่ไหมครับ
อันนี้ มันยังไงเหรอครับ
ใช่ครับ ก่อนปิด body
7elven Tue, 11/07/2017 - 16:10
In reply to คงจำได้ขึ้นใจละครับทีนี้ by Elysium
ใช่ครับ ก่อนปิด body สงสัยจะโดนตัดแท็กออกตอน submit
ส่วนเรื่องเดจาวู แค่คุ้นๆหน่ะครับ สงสัยช่วงนี้คงนอนน้อย
สวัสดีครับ พี่ๆ ที่เก่งเรื่อง
nine623 Sat, 18/04/2020 - 19:20
Hi
SAP HANA Training In Chennai
manimaran Tue, 14/07/2020 - 18:34
SAP HANA Training In Chennai
SAP MM Training In Chennai
Selenium Training In Chennai
Digital Marketing Training In Chennai
Angular js Training In Chennai
AWS Training In Chennai
<a href="https:/
manimaran Tue, 14/07/2020 - 18:35
CCNA Training In Chennai
Dot Net Training In Chennai
Hadoop Training In Chennai
Informatica Training In Chennai
PMP Training In Chennai
Salesforce Admin Training In Chennai
Scrum Master Training In Chennai
SEO Training In Chennai
Tally Training In Chennai
Splunk Training In Chennai
ServiceNow Training In Chennai