ผมต้องการที่จะเปิดช่องinputที่ได้มีการระบุreadonlyเพื่อให้ทำการเเก้ไขข้อมูลได้ต้องทำไงครับ
ถาม-ตอบ แนะนำไอเดียว โค้ดตัวอย่าง แนวทาง วิธีแก้ปัญหา ผมต้องการที่จะเปิดช่องinputที่ได้มีการระบุreadonlyเพื่อให้ทำการเเก้ไขข้อมูลได้ต้องทำไงครับ
ผมต้องการที่จะเปิดช่องinputที่ได้มีการระบุreadonlyเพื่อให้ทำการเเก้ไขข้อมูลได้ต้องทำไงครับ
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 | คือ ในช่องเเสดงข้อมูลที่เป็น input text ผมได้มีการกำหนด readonly เอาไว้ เเต่ผมก็จะใส่ปุ่ม button เอาไว้เพื่อใช้ในการกดเเก้ไขข้อมูล ซึ่งตรงการเเก้ไขข้อมูลนี้ ผมไม่ทราบว่าต้องเขียนอย่างไร รบกวนด้วยครับ <?php error_reporting ( error_reporting () & ~E_NOTICE); session_start(); require_once 'connect.php' ; $query_buyer = "SELECT * FROM customer WHERE cus_id " ; $result = mysqli_query( $con , $query_buyer ) or die (mysqli_error()); $row_buyer = mysqli_fetch_array( $result ); ?> <p><a href= "main1.php" >เลือกสินค้าเพิ่ม</a> </p> <table width= "700" border= "1" align= "center" class = "table" > <tr> <td width= "1558" colspan= "7" align= "center" > <strong>สั่งซื้อสินค้า</strong></td> </tr> <tr class = "success" > <td align= "center" >ลำดับ</td> <td align= "center" >ชื่อสินค้า</td> <td><center>ขนาด(นิ้ว)</center></td> <td><center>ความหนา(มม.)</center></td> <td><center>ความยาว(ม.)</center></td> <td align= "center" >จำนวน</td> <td align= "center" >รวม/รายการ</td> </tr> <form name= "formlogin" action= "Saveorder.php" method= "POST" id= "login" class = "form-horizontal" > <?php $order_total = 0; $pro_id = isset( $_GET [ 'pro_id' ]); $pro_stock = isset( $_GET [ 'pro_stock' ]); foreach ( $_SESSION [ 'shopping_cart' ] as $pro_id => $pro_stock ) { $sql = "select * from product where pro_id=$pro_id" ; $query = mysqli_query( $con , $sql ); while ( $row = mysqli_fetch_array( $query )) { $sum = $row [ 'pro_price' ] * $pro_stock ; $order_total += $sum ; $tex = ( $order_total * 0.07); $payment = ( $order_total + $tex ); ?> <tr> <td align= 'center' ><?php echo $i += 1; ?> </td> <td> <?php echo $row [ "pro_name" ]; ?> </td> <td> <?php echo $row [ "pro_size" ]; ?> </td> <td> <?php echo $row [ "pro_thickness" ]; ?> </td> <td> <?php echo $row [ "pro_length" ]; ?> </td> <!--<td align= 'right' ><?php echo number_format( $row [ 'pro_price' ], 2); ?> </td>--> <td align= 'right' ><?php echo $pro_stock ; ?></td> <td align= 'right' ><?php echo number_format( $sum , 2); ?></td> <!-- ราคารวมเเต่ละรายการ --> </tr> <?php } } ?> <tr> <td align= 'right' colspan= '6' ><b>รวม</b></td> <td align= 'right' ><b><?php echo number_format( $payment , 2); ?> </b> </td> </tr> </table> <br><br><br> <div class = "container" > <div class = "row" > <div class = "col-md-4" ></div> <div class = "col-md-6" style= "background-color:#f4f4f4" > <h3 align= "center" style= "color:green" > <span class = "glyphicon glyphicon-shopping-cart" > </span> ที่อยู่ในการจัดส่งสินค้า </h3> <table align= "center" cellpadding= "0" cellspacing= "1" class = "table table-hover" > <tr> <td width= "200" >คำนำหน้า</td> <td class = "" > <input name= "cus_perfix" type= "text" class = "box" id= "cus_perfix" readonly= "readonly" value= "<?php echo $row_buyer['cus_perfix']; ?>" size= "32" maxlength= "32" ></td> </tr> <tr> <td width= "200" >ชื่อ</td> <td class = "" > <input name= "cus_name" type= "text" class = "box" id= "cus_name" readonly= "readonly" value= "<?php echo $row_buyer['cus_name']; ?>" size= "32" maxlength= "32" ></td> </tr> <tr> <td width= "200" >นามสกุล </td> <td class = "" > <input name= "cus_surname" type= "text" class = "box" id= "cus_surname" readonly= "readonly" value= "<?php echo $row_buyer['cus_surname']; ?>" size= "32" maxlength= "32" ></td> </tr> <tr> <td width= "150" >เบอร์โทรศัพท์ </td> <td> <input name= "cus_number" type= "tel" class = "box" id= "cus_number" value= "<?php echo $row_buyer['cus_number']; ?>" size= "32" maxlength= "32" ></td> </tr> <tr> <td width= "150" >ที่อยู่</td> <td class = "" > <input name= "cus_address" type= "text" class = "box" id= "cus_address" value= "<?php echo $row_buyer['cus_address']; ?>" size= "32" maxlength= "50" ></td> </tr> <tr> <td width= "150" >ตำบล</td> <td class = "" > <input name= "cus_district" type= "text" class = "box" id= "cus_district" value= "<?php echo $row_buyer['cus_district']; ?>" size= "32" maxlength= "32" ></td> </tr> <tr> <td width= "150" >อำเภอ</td> <td class = "" > <input name= "cus_prefecture" type= "text" class = "box" id= "cus_prefecture" value= "<?php echo $row_buyer['cus_prefecture']; ?>" size= "32" maxlength= "32" ></td> </tr> <tr> <td width= "150" >จังหวัด</td> <td class = "" > <input name= "cus_province" type= "text" class = "box" id= "cus_province" value= "<?php echo $row_buyer['cus_province']; ?>" size= "32" maxlength= "32" ></td> </tr> <tr> <td width= "150" >รหัสไปรษณีย์ </td> <td> <input name= "cus_zip_code" type= "text" class = "box" id= "cus_zip_code" value= "<?php echo $row_buyer['cus_zip_code']; ?>" size= "32" maxlength= "32" ></td> </tr> </table> <div class = "form-group" > <div class = "col-sm-12" align= "center" > <input name= "cus_id" type= "hidden" id= "cus_id" value= "<?php echo $row_buyer['cus_id']; ?>" > <button type= "submit" class = "btn btn-primary" id= "btn" >ยืนยันสั่งซื้อ </button> <button type= "button" class = "btn btn-danger" id= "btn2" >แก้ไข </button> </div> </div> </div> </div> </div> <br><br> </form> |

คำแนะนำ และการใช้งาน
สมาชิก กรุณา ล็อกอินเข้าระบบ เพื่อตั้งคำถามใหม่ หรือ ตอบคำถาม สมาชิกใหม่ สมัครสมาชิกได้ที่ สมัครสมาชิก
- ถาม-ตอบ กรุณา ล็อกอินเข้าระบบ
ความคิดเห็นที่
1
ใช้ jQuery ช่วย หลักๆ การจัดการกับ object จากการกระทำใดๆ จะอยู่ในรูปแบบ
1 2 3 | $( "selector ที่มีการกระทำเกิดขึ้น" ).on( "event หรือเหตุการณ์ที่ตรวจจับ" ,ฟังชั่นการทำงาน(){ /// }); |
เช่น
1 2 3 | $( "#edit_obj1" ).on( "click" , function (){ alert( "Test" ); }); |
สิ่งที่ต้องศึกษา คือ
Selectors
https://api.jquery.com/category/selectors/
Events
http://api.jquery.com/Types/#Event
ส่วนการแก้ไข ปรับปรุง เปลี่ยนแปลง element หรือ object ให้ดูเกี่ยวกับการ Manipulation
http://api.jquery.com/category/manipulation/
อย่างกรณีที่ต้องการ เดิมมี element อยู่สองตัว คือ input text และ button สมมติว่ามี id เป็น
obj1 และ edit_obj1 ตามลำดับ
สิ่งที่เราต้องการคือ ให้จากเดิม input text ที่มี attribute ว่า readonly อยู่ ให้เอา attribute นี้ออกไป
เพื่อที่จะให้สามารถแก้ไขรายการได้
1 2 | <input type= "text" id= "obj1" value= "test" readonly> <!-- เดิม--> |
อยากให้เป็น
1 2 | <input type= "text" id= "obj1" value= "test" > <!-- อยากให้เป็น --> |
วิธีการ คือทำอย่างไรให้ค่า readonly หายไป หรือมีค่าเป็น false เราก็ไปดูวิธีการจัดการจากคำสั่งใน Manipulation
ซึ่งทำได้หลายวิธี เช่น
1 2 | $( "#obj1" ).attr( "readonly" ,false); <!--เปลี่ยนค่าเป็น false--> |
หรือ
1 2 | $( "#obj1" ).removeAttr( "readonly" ); <!--เอา attrribute นี้ออกไป--> |
เมื่อเอาทั้งสองส่วนมารวมกัน ระหว่าง เกิดเหตุการณ์เมื่อคลิกที่ปุ่มแก้ไข ให้ทำการกำหนดให้ input text สามารถแก้ไขได้
ก็จะได้เป็น
1 2 3 4 5 6 7 8 9 10 11 12 13 | <div class = "container w-75" > <input type= "text" id= "obj1" value= "test" readonly> <button type= "button" id= "edit_obj1" >Edit</button> </div> <script type= "text/javascript" > $( function (){ $( "#edit_obj1" ).on( "click" , function (){ $( "#obj1" ).attr( "readonly" ,false); }); }); </script> |
ลองดูไอเดียคำแนะนำ เป็นแนวทางต่อยอดต่อไป

ความคิดเห็นที่
2
ขอบคุณครับ

ขอบคุณทุกการสนับสนุน
![]()