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

เมธอด .serializeArray()  เพื่อรับข้อมูลจาก From 

การรับข้อมูลจาก form เราสามารถทำได้หลายวิธี จะส่งไปยัง backend หรือ ส่งไปฝั่งเซิฟเวอร์เลยก็ได้ เช่น เมื่อกรอกฟอร์มเสร็จแล้วส่งไปให้php รับค่าเลย  หรือจะใช้บางอย่างมาคั่นกลางก่อนส่งไป เพื่อทำตรวจสอบข้อมูลว่าถูกต้องหรือตามรูปแบบที่กำหนดหรือไม่  เราสามารถนำjQuery  ซึ่งเป็น JavaScript Library นี้มาใช้งานได้  บทความนี้จะทำตัวอย่างการรับค่าจาก form โดยใช้เมธอด .serializeArray() และแสดงผลเป็น Json หรือสใครจะเอาไปประยุกต์ต่อเพิ่มเติมก็ได้

เมธอด .serializeArray()  เป็นรูปแบบการสร้างชุดของ string ค่าตัวแปรในรูปแบบของ array เพื่อเหมาะสมต่อการส่งค่าตัวแปร และการนำไปใช้ 

ตัวอย่าง form 

<form>
  <div><input type="text" name="FN" value="John" id="FN"></div>
  <div><input type="text" name="LN" value="Minda" id="LN"></div>
  <div><input type="hidden" name="id" value="3" id="id"></div>
  <div>
    <textarea name="aboutme" rows="8" cols="40">I like apple</textarea>
  </div>
  <div><select name="gender">
    <option value="male" selected="selected">male</option>
    <option value="female">female</option>
  </select></div>
  <div>
    <input type="submit" name="submit" value="Submit">
  </div>
</form>

จาก form เราจะเห็นว่า มีกำหนด value เรียบร้อยแล้ว ซึ่ง value นี้คือเสมือนข้อมูลที่ผู้ใช้กรอกเข้ามาน่ะครับ

ต่อไปเราจะใช้  เมธอด .serializeArray()  เพื่อรับข้อมูลและ console.log ข้อมูลที่ได้รับมา โดยใช้โค้ดดังตัวอย่างนี้ 

$( "form" ).submit(function( event ) {
  console.log( $( this ).serializeArray() );
  event.preventDefault();
});

Method .serializeArray()   จะทำการเตรียมข้อมูลจากฟอร์มเพื่อใช้งานโดยจัดในรูปแบบ javascript array ของ object โดยแต่ละ object จะมีProperties  ชื่อ name
และ value

ผลลัพธ์ที่ได้มาผ่าน console ดังนี้ครับ

[
  {
    name: "FN",
    value: "John"
  },
  {
    name: "LN",
    value: "Minda"
  },
  {
    name: "ID",
    value: "3"
  },
  {
    name: "aboutme",
    value: "I like apple"
  },
  {
    name: "gender",
    value: "male"
  }
]

ในผลลัพธ์ เราเพียงแค่ใช้เมธอดนี้ครั้งเดียวสามารถรับข้อมูลจากฟอร์มได้ทุกฟิลต์ ไม่จำเป็นต้องรับทีละอย่างทีละครั้งและโค้ดที่ยาวยื่ด โดยการใช้ selecter  'form' ร่วมกับ เมธอด .serializeArray()  หวังว่าสามารถนำไปประยุกต์ต่อให้เข้ากับโปรเจ็คของเราน่ะครับ 

 

ช่องทางการศึกษาเพิ่มเติมข่าวที่น่าสนใจเกี่ยวกับ : Jquery

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
Celeb net worth?
โดย Bailey99 ศ 05 มิ.ย. 2020 7:03 pm บอร์ด PHP Knowledge
1
78
ศ 05 มิ.ย. 2020 7:28 pm โดย rajneeskumar
วิธีการ ใช้งาน vuetify คู่กับ vue.js
โดย bolue ศ 05 มิ.ย. 2020 6:02 pm บอร์ด CSS Knowledge
0
44
ศ 05 มิ.ย. 2020 6:02 pm โดย bolue
วิธีการ ติดตั้ง vue.js สำหรับผู้เริ่มต้น หัดเขียน สอนติดตั้ง
โดย bolue ศ 05 มิ.ย. 2020 4:55 pm บอร์ด Jquery & Ajax Knowledge
0
108
ศ 05 มิ.ย. 2020 4:55 pm โดย bolue
วิธีการ ใช้ Grid ออกแบบเป็น responsive design โดย vuetify
โดย bolue ศ 05 มิ.ย. 2020 3:36 pm บอร์ด CSS Knowledge
0
77
ศ 05 มิ.ย. 2020 3:36 pm โดย bolue
วิธีการ เรียนใช้ dialog จาก components โดย vue.js
โดย bolue ศ 05 มิ.ย. 2020 1:45 pm บอร์ด Jquery & Ajax Knowledge
0
68
ศ 05 มิ.ย. 2020 1:45 pm โดย bolue
วิธีการ การเรียกใช้ methods โดย vue.js
โดย bolue ศ 05 มิ.ย. 2020 1:17 pm บอร์ด Jquery & Ajax Knowledge
0
36
ศ 05 มิ.ย. 2020 1:17 pm โดย bolue
วิธีการ ค้นหาด้วยการใช้ watch โดย vue.js
โดย bolue ศ 05 มิ.ย. 2020 12:45 pm บอร์ด Jquery & Ajax Knowledge
0
32
ศ 05 มิ.ย. 2020 12:45 pm โดย bolue
วิธีการ แสดงผลข้อมูล จากน้อยไปมาก มากไปน้อย โดย Python
โดย bolue ศ 05 มิ.ย. 2020 11:56 am บอร์ด Python Knowledge
0
37
ศ 05 มิ.ย. 2020 11:56 am โดย bolue
วิธีการ ค้นหาแบบช่วงวันที่ โดย Python
โดย bolue ศ 05 มิ.ย. 2020 11:25 am บอร์ด Python Knowledge
0
42
ศ 05 มิ.ย. 2020 11:25 am โดย bolue
กองทุนประกันสังคม มีผู้ประกันตนกี่ประเภท ??
โดย natthanit.r2538 พฤ 04 มิ.ย. 2020 5:53 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
0
38
พฤ 04 มิ.ย. 2020 5:53 pm โดย natthanit.r2538
วิธีการ ลงเวลา โดย Python
โดย bolue พฤ 04 มิ.ย. 2020 4:09 pm บอร์ด Python Knowledge
0
72
พฤ 04 มิ.ย. 2020 4:09 pm โดย bolue
การยื่นแบบ ภ.ง.ด. 53 ออนไลน์ สอนวิธีการยื่นแบบออนไล์ ทำได้ด้วยตัวเอง
โดย natthanit.r2538 พฤ 04 มิ.ย. 2020 3:51 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
1
67
พฤ 04 มิ.ย. 2020 4:16 pm โดย natthanit.r2538
วิธีการ โชว์ข้อมูลด้วยการ Format วันที่ โดย Python
โดย bolue พฤ 04 มิ.ย. 2020 3:38 pm บอร์ด Python Knowledge
0
65
พฤ 04 มิ.ย. 2020 3:38 pm โดย bolue
การยื่นแบบ ภ.ง.ด. 3 ออนไลน์ สรุปขั้นตอนยื่นแบบภาษี ออนไลน์
โดย natthanit.r2538 พฤ 04 มิ.ย. 2020 2:54 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
1
53
พฤ 04 มิ.ย. 2020 3:08 pm โดย natthanit.r2538
วิธีการเดินทางจาก ปทุมธานี มา กรุงเทพฯ
โดย bolue พฤ 04 มิ.ย. 2020 1:59 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
41
พฤ 04 มิ.ย. 2020 1:59 pm โดย bolue
วิธีการ Search database แบบพื้นฐานๆ โดย Python
โดย bolue พฤ 04 มิ.ย. 2020 1:55 pm บอร์ด Python Knowledge
0
73
พฤ 04 มิ.ย. 2020 1:55 pm โดย bolue
การยื่นแบบ ภ.ง.ด.1 ออนไลน์ ขั้นตอนการยืนแบบออนไลน์
โดย natthanit.r2538 พฤ 04 มิ.ย. 2020 12:35 pm บอร์ด Accounting software & ERP โปรแกรมบัญชี ระบบอีอาร์พี
2
59
พฤ 04 มิ.ย. 2020 1:40 pm โดย natthanit.r2538
สอบถามเรื่องการแนบรูปในกระทู้ค่ะ
โดย natthanit.r2538 พฤ 04 มิ.ย. 2020 12:34 pm บอร์ด ปัญหาการใช้ phpBB3, SMF, Joomla, Wordpress, CMS, CRM
2
66
พฤ 04 มิ.ย. 2020 2:31 pm โดย natthanit.r2538
B - ยังขาดหน้าผลการค้นหา จาก search.php
โดย mindphp ศ 29 พฤษภาคม 2020 6:11 am บอร์ด FDD (Main)
0
1
ศ 29 พฤษภาคม 2020 6:11 am โดย mindphp
B - กล่องค้นหาจากหน้า index ใช้งานไม่ได้ กดแล้วไม่ไปหน้าค้นหา
โดย mindphp ศ 29 พฤษภาคม 2020 5:39 am บอร์ด FDD (Main)
1
1
ศ 29 พฤษภาคม 2020 5:53 am โดย mindphp