ข้ามไปที่เนื้อหาหลัก

บทความ

กำลังแสดงโพสต์จาก สิงหาคม, 2018

SyntaxError: JSON.parse: unexpected non-whitespace character after JSON data

วิธีแก้ปัญหา SyntaxError: JSON.parse: unexpected non-whitespace character ปัญหาที่เกิดขึ้นคือ เมื่อมีการ submit ผ่าน iframe และให้ PHP คืนค่าเป็น JSON $json = json_encode(array(                                     "is_successful" => FALSE,                                     "message" => $message )); echo $json; ผลที่ได้คือ หน้าเว็บค้าง ไม่มีอะไรตอบสนองหรือทำงานต่อจากนั้นเลย และเมื่อเปิด console ขึ้นมาดูก็พบข้อความแจ้ง error ดังนี้ SyntaxError: JSON.parse: unexpected non-whitespace character after JSON data at line 1 column 921 of the JSON data ทั้งที่ค่าคืนกลับมาใน iframe ก็ปกติดี โค้ดในส่วนของการดึงข้อมูลใน iframe หลังจาก Submit เรียบร้อยมีดังนี้ var c = 0; $("#post_iframe").on('load',function() { c++; if(c==1){ iframeContents = this.contentWindow.document.body.innerHTML; var...

PHP CI MANIA : PHP CodeIgniter Generator โปรแกรมช่วยสร้างโค้ด ลดเวลาการเขียนโปรแกรม

ราคาแต่ละเวอร์ชั่น   (ราคา 1,500 .- / 2,990.- / 3,990 .-)        จะเริ่มที่เวอร์ชั่น 0.1 ถึง 0.9 โดยความสามารถเริ่มต้นคือ        1) หน้าแสดงรายการทั้งหมด จะสามารถค้นหา และแบ่งหน้าได้อัตโนมัติ        2) หน้าเพิ่มข้อมูล จะสามารถกำหนดจำนวน INPUT ที่ต้องการป้อนข้อมูลได้        3) หน้าแสดงรายละเอียดเรคอร์ด สามารถคลิกเลือกรายการที่ต้องการดูข้อมูลทั้งหมดได้        4) หน้าแก้ไขข้อมูล สามารถคลิกแก้ไขข้อมูลในแต่ละเรคอร์ดจากหน้าแสดงรายการได้        5) การลบข้อมูล สามารถคลิกลบรายการในแต่ละเรคอร์ดได้        6) มีระบบ Login และบริหารจัดการข้อมูลสมาชิกได้        นอกจากนี้ระบบยังรองรับส่วนของการ JOIN TABLE อื่นๆได้อีกด้วย เช่น ฟิลด์ที่เก็บรหัสสมาชิก จะสามารถ JOIN ไปยังตารางสมาชิก เพื่อดึงชื่อมาแสดงผลได้ด้วย        และความสามารถอีกอย่างที่จำเป็นอย่างยิ่งนั่นก็คือ รองรับการเชื่อมโยงกับตา...

K Plus จ่ายค่าไฟฟ้าส่วนภูมิภาค ผ่านแอพฯ PEA Smart Plus

การทำงานร่วมกันของ PEA Samrt Plus กับ K PLUS - ธนาคารกสิกรไทย หลังจากที่พยายามหาเมนูจ่ายค่าไฟ(การไฟฟ้าส่วนภูมิภาค) อยู่หลายครั้งหลายหน พยายามจ่ายด้วยเมนู การไฟฟ้านครหลวง อยู่หลายครั้งก็ไม่สำเร็จ (จะจ่ายได้ไงเล่า มันคนละส่วนกันกับการไฟฟ้าส่วนภูมิภาค) ก็ลองค้นหาใน Google และเลื่อนไปเปิดกระทู้พันทิปมาอ่าน ก็ได้ความว่า ต้องติดตั้งแอพ PEA Samrt Plus ก่อนจึงจะสามารถชำระเงินได้ หลังจากติดตั้งเรียบร้อย เปิดขึ้นมาก็จะเจอส่วนของการลงทะเบียน เมื่อลงทะเบียนเรียบร้อยก็มาเพิ่มสถานที่ใช้ไฟฟ้า - จะแสกน QR Code/Barcode - หรือ จะกรอกเองตามตัวอย่างบนบิลค่าไฟก็ได้ กรอกข้อมูลเรียบร้อยให้สังเกตข้อมูลชื่อเจ้าของผู้ใช้ และยอดค้างชำระว่าถูกต้องหรือไม่ ถ้าถูกต้องกดที่เข้าไปเพื่อชำระค่าไฟค้างจ่าย หรือจะเข้าไปที่เมนู ชำระค่าไฟฟ้า ด้านล่างก็ได้ ถ้ามีค่าไฟฟ้าค้างจ่าย จะปรากฏกลางจอภาพให้เลือก (แต่ในภาพด้านล่างนี้ชำระไปแล้วก็เลยว่างเป่า) เมื่อกดเลือกรายการที่ต้องการชำระเรียบร้อย ให้เลือก บัญชีธนาคาร หลังจากกดเลือกบัญชีธนาคารแล้ว จะมีรายชื่อธนาคารให้เลือก - ...

ตัวอย่างการใช้ HTML5 Canvas วาด ER Diagram

มาดูตัวอย่างการใช้ Canvas วาด ER Diagram กันครับ ถ้าดูในโค้ดด้านล่างนี้ จะสังเกตเห็นว่าส่วนของ //LEFT หรือตาราง Master และส่วนของ //RIGHT หรือตาราง Detail ทั้งสองส่วนนี้ จะทำงานซ้ำๆกัน ซึ่งถ้านำไปใช้จริงก็จะเป็นการดึงฟิลด์ของตารางที่เกี่ยวข้องออกมาวนลูป เพื่อแสดงชื่อฟิลด์ในช่องแต่ละช่อง ตามจำนวนฟิลด์ที่มีในตารางแต่ละตาราง ตัวอย่างโค้ดวาด ER Diagram <!DOCTYPE HTML> <html>   <head>     <style>       body {         margin: 0px;         padding: 0px; background-color : #eeeeee; text-align : center;       } canvas#myCanvas{ border: 1px solid #cccccc; background-color : #ffffff; }     </style>   </head>   <body>     <canvas id="myCanvas" width="1024" height="600"></canvas>     <script> var canvas = document.getElementById('myCanvas'); var context = canvas.getConte...

Bootstrap Flowchart - สร้างโฟลวชาร์ตระบบแบบง่ายๆ

Bootstrap Determination Flowchart ตัวอย่างการทำโฟลชาร์ตแบบง่ายๆ ด้วย Bootstrap Frmaework ซึ่งน่าจะนำไปใช้ประโยชน์ต่อการสร้างระบบจัดการโปรเจ็กต์ของเราได้ และสิ่งที่น่าสนใจอีกอย่างคือ เมื่อนำไปเชื่อมโยงกับระบบ CodeIgniter Generator ที่ผมกำลังสร้างมานั้น อาจจะสามารถสร้างระบบการจัดการโปรเจ็กต์พร้อมสร้างโครงสร้างไฟล์ที่จำเป็นได้เสร็จสรรพ ที่มา : https://bootsnipp.com/snippets/a36yo PHP  CI  MANIA   -  PHP Code Generator  โปรแกรมช่วยสร้างโค้ด ลดเวลาการเขียนโปรแกรม เขียนโปรแกรมง่ายและสะดวกขึ้น สนใจสั่งซื้อราคาสุดคุ้ม >>  http://fastcoding.phpcodemania.com/

PHP จัดตารางการแข่งขันฟุตบอล / บาสเกตบอล / กีฬาประเภทพบกันทุกทีมเหย้า-เยือน

PHP generate football schedule ในโค้ดตัวอย่างด้านล่างนี้ จะเป็นการวนลูป for อยู่ด้วยกันทั้งหมด 3 รอบ for ครั้งที่ 1  กำหนดให้นับแค่ 2  ในลูปแรกจะเป็นทีมเหย้า ในลูปที่สองจะเป็นทีมเยือน for ครั้งที่ 2 จะนับตามจำนวนทีม ในตัวอย่างมี 8 ทีมก็จะนับจนกว่าจะครบ 8 ทีม for ครั้งที่ 3 จะนับตามจำนวนทีมคู่แข่ง ในตัวอย่างมี 8 ทีม ก็จะพบคู่แข่งอีก 7 ทีม  (ซึ่งพบกัน 2 ครั้ง เหย้า-เยือน ก็จะเท่ากับ 14 ครั้ง) ข้อสังเกต เมื่อขึ้น Day 9 จะมีการสลับเอาทีมเยือนขึ้นมาเป็นทีมเหย้า Team 2 จึงเป็นเจ้าบ้านรับการมาเยือนของ Team 1 แทน สำหรับโค้ดที่ใช้เป็นตัวอย่าง มีดังต่อไปนี้ [PHP CODE] <?php $teams = array( 'Team 1', 'Team 2', 'Team 3', 'Team 4', 'Team 5', 'Team 6', 'Team 7', 'Team 8' ); $team_logo[0] = 'https://cdn4.iconfinder.com/data/icons/pokemon-go/512/Pokemon_Go-15-512.png'; $team_logo[1] = 'https://cdn4.iconfinder.com/data/icons/pokemon-go/512/Pokemon_Go-16-512.png';...

JavaScript เปลี่ยนตัวพิมพ์ใหญ่ให้กับอักษรตัวแรกเหมือน ucfirst() ของ PHP

JavaScript กับการกำหนดตัวแรกเป็นตัวพิมพ์ใหญ่ สร้างฟังก์ชั่น JavaScript เพื่อทำให้ตัวแรกเป็นตัวพิมพ์ใหญ่ function jsUcfirst(string)  {      return string.charAt(0).toUpperCase() + string.slice(1); } วิธีการเรียกใช้งาน <input name="controller_name" onchange="this.value=jsUcfirst(this.value)" /> โค้ดด้านบนนี้จะทำงานเมื่อเกิดการเปลี่ยนแปลงข้อมูลในช่องกรอกข้อมูลที่ชื่อ controller_name จะเรียก onchage ขึ้นมาทำงาน this.value=jsUcfirst(this.value) คือคำสั่ง JavaScript ที่กำหนดให้ค่า value ของช่องกรอกข้อมูลตัวนี้ มีค่าเท่ากับค่าที่เปลี่ยนตัวแรก เป็นตัวพิมพ์ใหญ่ไปแล้ว มาดูกันทีละขั้นตอนว่าเกิดอะไรขึ้นบ้างในฟังก์ชั่นนี้ เราจะสามารถแยกออกได้ 3 เหตุการณ์ด้วยกัน คือ เหตุการณ์ที่ 1 => string.charAt(0) เหตุการณ์ที่ 2 => .toUpperCase() เหตุการณ์ที่ 3 => + string.slice(1); สมมติว่าเราส่งคำว่า members เข้าไปในฟังก์ชั่น jsUcfirst() string.charAt(0) จะทำการตัดอักษรตัวแรกออกมาจาก string จะได้คำว่า m ออกมา .toUpperCase() จะทำงานต่อทันทีหลังจาก...

มันเป็นเรื่องของเหตุผล ที่เมื่อผลลัพธ์ Callback มาแล้วไม่มีฟังก์ชั่นไหน Validate สิ่งที่ได้รับกลับมาเท่านั้นเอง

+++ ทำความดีควรหวังผล แต่ไม่ต้องหวังสิ่งตอบแทน +++ ผมอาจจะจั่วหัวดูชวนสงสัยกันสักหน่อย เพราะเรามักจะได้ยินคำว่า  " ทำดีไม่หวังผลตอบแทน " ผมก็แค่เติมคำใหม่เข้าไปว่า ควรหวังผล เพราะถ้าเราไม่หวังผล แล้วเราจะรู้ได้อย่างไรว่าสิ่งที่ทำลงไป "นั้นดีจริง" บุญ นั้นเกี่ยวข้องกับเรื่องของ เหตุ และ ผลแห่งกรรม กับคำถามที่ว่า  ทำบุญหวังผลตอบแทนจะไม่ได้บุญจริงหรือ??? ว่าด้วยเรื่องของ เหตุและผล เมื่อเราทำลงไปแล้ว ต่อให้อยากได้หรือไม่อยากได้ ผลจากสิ่งที่เราทำไปแล้วนั้น ย่อมกลับมาหาเราแน่นอน ไม่ทางใดก็ทางหนึ่ง ดังนั้น เมื่อเราทำบุญ เราย่อมได้บุญแน่นอน  ไม่ว่าเราจะอยากได้หรือไม่อยากได้ก็ตาม แต่คำถามที่ควรถามจริงๆคือ ผลบุญที่เราอยากได้นั้นใช่ผลบุญที่ได้รับจริงหรือไม่? "เราคงไม่อาจหาฟังก์ชั่นไหนใช้ Validate สิ่งที่ Callback กลับมาได้" มันก็เหมือนกับเราขยันอ่านหนังสือสอบ เราก็จะสอบได้เกรดดีๆ ตามที่เราหวังไว้ นี่ก็คืออีกหนึ่งการสร้างบุญของวัยเรียน มันคือสิ่งดีๆที่เราทำให้ตัวเอง และพ่อแม่ได้ชื่นใจ ดั...

รวบรวมข้อมูลสำหรับสร้าง เครื่องผสมเมนูเครื่องดื่มอัตโนมัติ - ชงกาแฟอัตโนมัติ

แนวคิดจากคลิปวิดีโอ เครื่องกดน้ำอัดลม DIY ไอเดียสำหรับต่อยอด สร้างวงจรควบคุมระยะเวลาปั๊มด้วยการจ่ายไฟผ่านระบบ ไมโครคอนโทรลเลอร์ (Micro Controller) เพื่อเลือกเมนูแต่ละเมนู ที่กำหนดระยะเวลาของการจ่ายไฟให้ปั๊มแต่ละตัวต่างกัน และกำหนดระดับความหวานได้หลายระดับ ซึ่งแต่ละระดับก็จะมีระยะเวลาการจ่ายไฟที่ต่างกัน ตัวอย่าง ขา 1 = ปั๊มจ่ายน้ำเชื่อม ขา 2 = ปัมจ่ายนมสด ขา 3 = ปั๊มจ่ายนมข้นหวาน ขา 4 = บลูฮาวาย ขา 5 = แคนตาลูป หวานระดับ 1 ขา 1 จ่ายไฟออกหน่วงเวลา 3 วินาที หวานระดับ 2 ขา 1 จ่ายไฟออกหน่วงเวลา 5 วินาที หวานระดับ 3   ขา 1 จ่ายไฟออกหน่วงเวลา 7 วินาที หวานระดับ 4   ขา 1 จ่ายไฟออกหน่วงเวลา 9 วินาที หวานระดับ 5   ขา 1 จ่ายไฟออกหน่วงเวลา 12 วินาที เมื่อเราจ่ายไฟไปยังปั๊มที่การหน่วงเวลาต่างกัน ระยะเวลาที่ปั๊มทำงานก็จะต่างกัน ซึ่งปริมาณน้ำเชื่อมที่ได้ของแต่ละระดับก็จะต่างกันไป และเมื่อเลือกเมนูอะไรไว้ ปั๊มที่เลือกไว้ก็จะทำงานตามระยะเวลาที่กำหนด และเมื่อครบตามจำนวนปั๊ม ก็จ่ายไฟเลี้ยงไปยังเครื่องผสมเครื่องดื่ม Self Stirring Mug ...

PHP MOD การหารเอาเศษ การคิดราคาสินค้าแบบแพ็ก แบบชิ้น

การคิดราคาสินค้าแบบแพ็ก    หลักการเบื้องต้นก็คือ 1. คิดราคาแบบเป็นแพ็ก $pack_buy = floor($customer_buy / $product_xx_pack_qty); //ปัดเศษทิ้ง $total_pack_buy_price = $pack_buy * $product_xx_pack_price;//คิดราคาแบบ pack ใน PHP เราจะใช้ฟังก์ชั่น floor() เพื่อปัดเศษทิ้ง เอาเฉพาะที่ครบจำนวนแพ็กเพื่อไปคูณกับราคาต่อแพ็ก แต่ถ้าไม่ครบก็จะนำไปคำนวณราคาต่อแพ็กแล้วได้ 0 2. หาราคาต่อชิ้น ที่เหลือจากการหารเพื่อหาแบบแพ็ก $piece_buy = $customer_buy % $product_xx_pack_qty;//หารแบบเอาเศษ $piece_price = $piece_buy * $product_xx_price;// ราคาของส่วนที่เหลือจากแพ็ก     แน่นอนว่าถ้าซื้อไม่ถึงแพ็ก ก็จะเป็นจำนวนชิ้นทั้งหมด  แต่ถ้าซื้อครบแพ็กพอดี จำนวนชิ้น ก็จะเป็น 0 เพราะคิดราคาแบบแพ็กเท่านั้น แต่ถ้าซื้อเกินแพ็กเศษเท่าไหร่ก็เอาไปคูณกับราคาต่อชิ้น

PHP เปรียบเทียบวันที่ หาผลต่างระหว่างวันที่ 2 วัน ด้วยฟังก์ชั่น DateTime

ในตัวอย่างนี้ เราจะหาผลต่างระหว่างวันที่ 2 วันด้วยฟังก์ชั่น PHP DateTime Class ซึ่งจะมีให้เรียกใช้ตั้งแต่ PHP เวอร์ชั่น  5.2.0 ขึ้นไป กำหนดให้ตัวแปร PHP ชื่อ $date1 และ $date2 รับค่าจากการส่งค่าแบบฟอร์มแบบ POST โดยจะใช้ isset() ตรวจสอบค่าก่อนว่าได้ส่งมาหรือไม่ ถ้ายังไม่ได้ส่งค่าจากแบบฟอร์มมา จะเซ็ตให้เป็นค่าว่าง เพราะกรณีเปิดหน้าเว็บขึ้นมา จะยังไม่ได้ส่งค่าใดๆ เมื่อได้ค่าจากแบบฟอร์มเราจะเรียกคลาส DateTime() ใน PHP คำนวณค่าให้ด้วยเมธอด/ฟังก์ชั่น diff() จากนั้นก็เซ็ต format() ให้อยู่ในรูปแบบที่ต้องการ ซึ่งอ่านเพิ่มเติมเกี่ยวกับรูปแบบได้ที่ Supported Date and Time Formats http://php.net/manual/en/datetime.formats.php สำหรับซอร์สโค้ด PHP ที่ใช้ทั้งหมดมีดังตัวอย่างต่อไปนี้ [ PHP Code ] <?php $date1 = isset($_POST['date1']) ? $_POST['date1'] : ''; $date2 = isset($_POST['date2']) ? $_POST['date2'] : ''; $datetime1 = new DateTime($date1); $datetime2 = new DateTime($date2); $interval = $datetime1->diff($dateti...

ค้นหาในเว็บไซต์

เนื้อเพลงที่ได้รับความนิยม ในรอบสัปดาห์

PHP CI MANIA 0.8.4.09 แก้ไขปัญหา Import ไฟล์ Excel แล้วไม่สามารถบันทึกได้ + เพิ่มตัวเลือก Validate บางฟิลด์

- เพิ่มตัวเลือก Validate บางฟิลด์ กรณีละเว้นการตรวจสอบให้เอาเครื่องหมายเช็คถูกออก -  แก้ไขปัญหา Import ไฟล์ Excel แล้วไม่สามารถบันทึกได้ สมาชิก Premium ดาวน์โหลดได้ที่ http://fastcoding.phpcodemania.com/index.php/downloads PHP  CI  MANIA   - PHP Code Generator  โปรแกรมช่วยสร้างโค้ด "ลดเวลาการเขียนโปรแกรม" ราคาสุดคุ้ม    http://fastcoding.phpcodemania.com

การทำ Index ให้ MySQL Database เพื่อเพิ่มความเร็ว

สำหรับตัวอย่างนี้จะเป็นการ JOIN ตาราง 2 ตาราง 1. tb_reject_hd 2. tb_reject_desc ซึ่งจะเชื่อมกันด้วยฟิลด์ docno จะเห็นว่าเราสามารถคิวรี่เรียกข้อมูลออกมาได้ตอนที่ยังไม่ใส่ ORDER BY แต่เมื่อใส่ ORDER BY เข้าไป จะหมุนค้างจนหน้าเว็บหยุดทำงาน จากนั้นก็ลองเพิ่ม INDEX ให้กับฟิลด์ docno ในตาราง tb_reject_desc  ซึ่งในตัวอย่างนี้จะสร้างตารางใหม่ขึ้นมาจากตารางเดิม เปลี่ยนชื่อเป็น tb_reject_desc_with_index และทำการเพิ่ม INDEX KEY เข้าไป เมื่อทดสอบคิวรี่แบบมี ORDER BY จะเห็นว่าสามารถแสดงผลได้ทันที จากการสังเกตตัวเลขเวลาในการประมวลผล จะเห็นได้ว่าแบบไม่ใช้ ORDER BY จะทำงานเร็วกว่า แต่ในการทำงานส่วนใหญ่ก็มักจะต้องใช้ ORDER BY อย่างหลีกเลี่ยงไม่ได้ เช่นกรณีค้นหา แบบเรียงลำดับ ตัวอย่างโค้ดคิวรี่ข้อมูลจากตารางที่ Add Index Key แล้ว <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <title>Add Index Key</title> </head> <body> <h2>ORDER BY with ...

การสร้างเว็บไซต์ในปี 2023 นั้นจะต้องคำนึงถึงอะไรบ้าง

การสร้างเว็บไซต์ในปี 2023 นั้นจะต้องคำนึงถึงความเปลี่ยนแปลงของเทคโนโลยีและแนวโน้มการใช้งานของผู้ใช้ใหม่ๆ ดังนั้น นี่คือเทคนิคที่สามารถช่วยให้การสร้างเว็บไซต์ในปี 2023 เป็นไปได้อย่างรวดเร็วและเป็นประสิทธิภาพ: 1. ใช้ Responsive Design: การออกแบบเว็บไซต์ให้สามารถปรับขนาดได้ตามขนาดของหน้าจอของอุปกรณ์ต่างๆ เช่น โทรศัพท์มือถือ แท็บเล็ต และคอมพิวเตอร์ เพื่อให้ผู้ใช้สามารถเข้าถึงและใช้งานได้ง่ายและสะดวก 2. ใช้โครงสร้างของ HTML5: การใช้โครงสร้าง HTML5 จะช่วยให้เว็บไซต์ของคุณมีประสิทธิภาพและปรับปรุงในเรื่องของการเข้าถึงข้อมูล การใช้งานและความปลอดภัย 3. ใช้ CSS Grids หรือ Flexbox: การใช้ CSS Grids หรือ Flexbox จะช่วยให้ง่ายต่อการจัดหน้าเว็บไซต์ และสามารถปรับแต่งรูปแบบของเว็บไซต์ได้ง่ายขึ้น 4. ใช้ JavaScript Frameworks: การใช้ JavaScript Frameworks เช่น React, Angular, หรือ Vue.js จะช่วยให้สามารถสร้างเว็บไซต์ที่เป็น interactive และมีประสิทธิภาพได้อย่างรวดเร็ว 5. ใช้ Content Management Systems (CMS): การใช้ CMS เช่น WordPress, Joomla, หรือ Drupal จะช่วยให้สามารถสร้างเว็บไซต์ได้อย่างร PHP  C...

แจกโค้ด PHP : รวมลิงค์ แจกฟรี!! ตัวอย่างโปรเจ็กต์ ที่พัฒนาด้วย PHP

       สำหรับหลายท่านที่ขอโค้ดเข้ามาทาง Inbox ของเฟซบุ๊กแฟนเพจ หรือถามถึงระบบต่างๆหลังไมค์มานั้น ส่วนใหญ่ก็มีแจกอยู่แล้วในเว็บบอร์ด ThaiCreate.Com นะครับ  และด้านล่างนี้ก็เป็น Source Code PHP ระบบต่างๆ ที่มีเหล่าผู้ใจดีแจกฟรี!! ให้นำไปลองใช้ลองศึกษากันครับ แจกฟรี  !! ตัวอย่างการ  PHP  Booking # จองห้องประชุม  ผ่านเว็บครับ http://www.thaicreate.com/php/forum/090558.html ระบบแบบสอบถาม https://www.thaicreate.com/php/forum/099342.html แจก code!! การทำประเมินออนไลน์มี ไว้สำหรับพัฒนาต่อยอด https://www.thaicreate.com/php/forum/102203.html แจกฟรี PHP CodeIgniter CMS ให้ทุกท่านได้ลอง (รองรับ Responsive) http://www.thaicreate.com/php/forum/122929.html โดย : https://www.cszcms.com/ แจก PHP : ระบบยืม-คืนเอกสาร (จากตัวอย่าง เอกสารข้อมูลวัตถุดิบสินค้า) http://www.thaicreate.com/php/forum/103428.html แจกระบบ PHP Shopping Cart ระบบตะกร้าสินค้า ระบบสั่งซื้อ มีระบบตัดสต๊อก, สั่งซื้อวัตถุดิบคงเหลือ ht...

จัดระเบียบโค้ด ใน Notepad++ (Auto indentation plugin)

เวลาเขียนโค้ด แล้วไม่ได้จัดรูปแบบ หรือเอาโค้ดจาก Text Editor หนึ่งมาใช้ในอีกตัวหนึ่งก็มีโอกาสที่ Tab หรือ Space bar จะต่างกัน แล้วเราจะมานั่ง TAB เองก็คงไม่ไหว จึงจำเป็นต้องหา Plugin เข้ามาช่วย ลองค้นดูก็เจอกับกระทู้นี้ >> แม้หน้าตาจะไม่ตรงกันแต่หลักๆก็คือเพิ่ม Plugins เข้าไปชื่อ Indent By fold อ่านเต็มๆได้ที่นี่ https://softwarerecs.stackexchange.com/questions/1496/auto-indentation-plugin-for-notepad

PHP เบื้องต้น | รวมวิดีโอสอนเขียนโปรแกรม PHP & MySQL

1. พื้นฐาน PHP     1.1  โครงสร้างการเขียน PHP ร่วมกับ HTML     1 .2  Selection Structure : การเขียนโปรแกรมแบบทางเลือก     1. 3  ตัวแปร (Variable) และ ค่าคงที่ (Constant)     1.4  ตัวดำเนินการ (Operator)     1.5  เครื่องหมาย Single Quote / Double Quote และ Escape Sequence     1.6  Repetition Structure (การเขียนโปรแกรมวนซ้ำ)          1.7  การแทรกโค้ PHP ส่วนต่างๆของ HTML     1.8  PHP Function 2. PHP MySQLi CRUD : การจัดการฐานข้อมูล MySQL เบื้องต้น      2.1 : การบันทึกข้อมูลด้วย MySQLi Function      2.2 การค้นหาและแสดงข้อมูลในรูปแบบตาราง 1/2     2.3  การค้นหาและแสดงข้อมูลในรูปแบบตาราง 2/2      2. 4 การแก้ไขข้อมูลด้วยคำสั่ง UPDATE     2. 5 การลบข้อมูลจากฐานข้อมูล     2. 6 การป้องกัน SQL Injection ด้วยการใช้ prepare และ bindparam           2.7 กา...

PHP CI MANIA : ตอนที่ 12 การใช้งานระบบสมาชิกกำหนดสิทธิ์เข้าใช้งานด้วย Login SESSION

เริ่มจากการสร้างหน้าเว็บแบบไม่กำหนดสิทธิ์ และกำหนดสิทธิ์ให้ สมาชิกเท่านั้น ที่เข้าหน้าเว็บที่กำหนดได้     1. ทดลองสร้างหน้าเว็บแบบปกติ เมื่อกำหนดชื่อต่างๆเรียบร้อย ก็คลิกสร้างไฟล์ Models, Views, JS และ Controller ให้เรียบร้อย (สำหรับ Version 0.6 จะมีปุ่ม " สร้างไฟล์ทั้งหมด ")    2. จากนั้นคลิกลิงค์เพื่อดูตัวอย่าง(ในหน้า Controller) จะพบกับหน้าเว็บที่เราสร้างเอาไว้ จะเห็นว่า สามารถเข้าได้ปกติ     3. สลับไปที่หน้า "ตั้งค่า" และคลิกเลือก "Login Require" เพื่อกำหนดว่า จะเข้าหน้าเว็บนี้ได้ จะต้องผ่านการ Login ก่อนเท่านั้น จากนั้นก็คลิกสร้างไฟล์ Models, Views, JS และ Controller ให้เรียบร้อย (สำหรับ Version 0.6 จะมีปุ่ม " สร้างไฟล์ทั้งหมด ")    4. จากนั้นคลิกลิงค์เพื่อดูตัวอย่าง(ในหน้า Controller) จะพบกับหน้าเว็บที่ ต้อง Login ก่อน จึงจะสามารถเข้าใช้งานได้    สำหรับ รหัสที่ใช้ทดสอบ นั้นได้กำหนดค่าเบื้องต้นไว้ให้ดังนี้    - Admin     ใช้ชื่อล็อกอิน admin รหัสผ่าน 123456     -...

วิธีแก้ไข JavaScript โดยไม่ต้อง Refresh หน้าเว็บใหม่

แก้ไข JavaScript โดยไม่ต้อง Refresh เป็นปกติทุกครั้งที่แก้ไขโค้ด JavaScript เราจำเป็นจะต้องรีเฟรชหน้าเว็บใหม่ทุกครั้ง แต่วันนี้ผมจะมาแนะนำวิธีรัน JavaScript ให้พร้อมใช้งานโดยไม่ต้องโหลดหน้าเว็บใหม่มาแนะนำครับ (สำหรับกรณีที่กำลังป้อนข้อมูลแบบฟอร์ม แล้วไม่อยากป้อนใหม่ เวลาที่ JavaScript error) ( แก้ปัญหาเวลาแก้ไข JavaScrip, CSS อัพขึ้นโฮสต์แล้วต้องกด CTRL + F5 เพื่อโหลดไฟล์ใหม่ทุกครั้ง ) ปัญหาเริ่มจากกดปุ่มลบ แล้ว Page not found  (หรือกรณี Event ใดๆ ที่กดปุ่มแล้ว JavaScript ไม่ทำงาน) ลองตรวจสอบ URL ที่ส่งไปเป็น / remove_price ซึ่งเกิดจากการระบุในไฟล์ JavaScript ไม่ตรงกับหน้าเว็บ เมื่อเปิดไปที่ไฟล์ PHP ในหน้าเว็บสำหรับลบราคา ปรากฏว่า URL ที่ถูกต้องคือต้องลงท้ายด้วย / removePrice ดังนั้นก็ต้องกลับไปทำการแก้ไขในไฟล์ .js ให้เป็น URL ที่ถูกต้อง  แต่ JavaScript เมื่อแก้ไขเสร็จเราจะต้อง Refresh หน้าเว็บเพื่อโหลดสคริปต์ใหม่ ซึ่งบางทีเราก็แก้ไขแค่จุดเดียว หากไม่อยากเสียเวลาโหลดใหม่ เราก็คัดลอกโค้ดเฉพาะ Function ที่เราแก้ไข เอาไปรันใน...

SELECT ซ้อน SELECT (GROUP BY, HAVING, SUBQuery, COUNT)

เมื่อต้องการนับจำนวนรายการตามเงื่อนไข แต่ก็จำเป็นต้องใช้ GROUP BY เพราะการใช้ COUNT + DISTINCT ไม่สามารถดึงข้อมูลตามเงื่อนไขได้  อยากจะนับจำนวนสมาชิกที่ชำร ะเงิน ถ้าใช้ COUNT() ก็จะออกมาหมด ทำให้ได้จำนวนเกินจากความเป ็นจริง เพราะสมาชิกบางคนชำระมากกว่ า 1 ครั้ง ก็เลยต้องเอามา GROUP กันด้วย รหัสสมาชิกก่อน เพื่อตัดเรคอร์ดที่ซ้ำกันออ กไป สมาชิกจะชำระกี่ครั้ง ก็นับเป็น 1 คน (เพราะเป็นสมาชิกคนเดียวกัน ) จะเห็นว่า จะได้ยอดที่ถูกต้อง 139 แต่ข้อมูลมันแจกแจงรายการต้ อง 139 แถว ซึ่งเราไม่ได้อยากได้รายละเ อียด แค่อยากนับจำนวนเท่านั้นจะท ำไงล่ะทีนี้ ก็จัดการ SELECT ครอบ SELECT ไว้เลย ซึ่งก็คือการทำ SubQuery นั่นเอง ก็จะออกมาเรคอร์ดเดียว เป็นจำนวนที่ต้องการนำไปใช้ งานได้ทันที จริงๆแล้วเราใช้ DISTINCT ได้นะ ถ้าเงื่อนไขมีแค่เท่านี้ ไม่จำเป็นต้อง SubQuery ดูสิ พอนับแบบตัดรายการซ้ำกันออก ก็ได้ 139 พอดิบพอดีเลย ใช่ครับ ถ้าเงื่อนไขมีเพียงเท่านี้ก ็ใช้ได้เลย แต่ถ้ามีเงื่อนไขอื่นล่ะ??? ถ้าจะนับเฉพาะสมาชิกที่ชำระ เงินตั้งแต่ 150...

MySQL คำสั่ง SQL จัดเรียงคำตามตัวอักษร ภาษาไทย ในฟิลด์ที่กำหนด Collation เป็น utf-8

การจัดเรียงข้อมูลตามลำดับตัวอักษรไทย   CONVERT( name USING tis620 ) ASC การเรียงลำดับตัวอักษรแบบ tis-620 ในการเขียนโปรแกรม PHP เพื่อแสดงข้อมูลจากฐานข้อมูล MySQL การเขียนคำสั่ง SQL ให้จัดเรียงลำดับนั้น เราจะใช้ ORDER BY  และกำหนดฟิลด์ที่ต้องการจัดเรียงลำดับ เช่น ในตัวอย่างนี้จะเป็นการจัดเรียงตามลำดับตัวอักษรของชื่อเมนู นั่นก็คือฟิลด์ name นั่นเอง แต่ในขั้นตอนการสร้างฐานข้อมูลนั้น เราได้กำหนด Charset ของตารางและฟิลด์เป็นการจัดเรียง Collation แบบ utf-8 เอาไว้เพื่อให้รองรับภาษาแบบมาตรฐาน ดังนั้นเมื่อเขียนโปรแกรมสั่ง ORDER BY name ASC ก็จะมีการจัดเรียงที่จะให้คำที่มีสระนำหน้าอยู่หลัง ฮ. นกฮุก ไปเสียหมด จะเห็นว่าชื่อเมนูหรือสินค้าที่มี ข นำหน้าจะมาเป็นลำดับแรก ทั้งที่จริงๆแล้ว มีสินค้าที่เป็น ก อยู่หลายรายการ เพียงแต่ว่ามีสระนำหน้าอยู่เท่านั้นเอง จากรูปด้านบน จะมีรายการที่เป็น ก อยู่ 3 รายการ คือเมนู โกโก้ ต่างๆ แต่เพราะมีสระโอ นำหน้า จึงทำให้การจัดเรียงแบบ utf-8 ให้อยู่ในลำดับท้าย เพื่อแก้ไขปัญหานี้ การเขียนโปรแกรมเพื่อ ORDER BY จะต้...

ค้นหาบล็อกนี้