Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,027

HOME > PHP > PHP Forum > ขอปรึกษาเกี่ยวกับการส่งมามาแสดงผลของ ajax ให้ไปแสดงผลในส่วนของ array หน่อยครับ



 

ขอปรึกษาเกี่ยวกับการส่งมามาแสดงผลของ ajax ให้ไปแสดงผลในส่วนของ array หน่อยครับ

 



Topic : 097760



โพสกระทู้ ( 283 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook



ขอปรึกษาเกี่ยวกับการส่งมามาแสดงผลของ ajax ให้ไปแสดงผลในส่วนของ array หน่อยครับ



Code (PHP)
	 $('#name_material').keyup(function(){
		
			url = 'ajax_material.php',
		  $.post(url,
			{ mat_list: $(this).val()},
			   
		  function(data)
		  {
				 if(data.success)
				 {
					  $('#type_unit').val(data.message);
					  $(.mat_list).val(data.mat_code);
				 }
		  },'json');
		return false;	  				
			
	 });  



<p>
            <label>ชื่อวัตถุดิบ <span class="require">*</span>:</label>
             <select name="name_material[]" id="name_material">
              <option value="">-- เลือกวัตถุดิบ --</option>
              <?
				  $qry_list = mysql_query("select mat_code, mat_name from material where mat_status='1'");
				  while($arr_list=mysql_fetch_array($qry_list))
				  {
					  echo "<option value='".$arr_list['mat_code']."'>".$arr_list['mat_name']."</option>";
				  }
				   ?>
            </select>                 
          </p>              
          <p>
           	<label>รหัสวัตถุดิบ <span class="require">*</span>:</label>
            	<input name="mat_list[]" type="text" id="mat_list" class="mat_list" readonly="readonly" />
          </p>                         
          <p>
            <label>จำนวน <span class="require">*</span>:</label>
              <input type="text" name="qty[]" id="qty" />
          </p>  




จากรูป จะเป็นว่า เมื่อมีการเลือกวัตถุดิบ จะส่งค่ามาแสดงผลในส่วนของรหัสวัตถุดิบ

หากมีการเพิ่มวัตถุดิบเข้ามาใหม่

เมื่อทำการเลือกรหัสวัตถุดิบ ค่าของรหัสวัตถุดิบทั้ง 2 ช่องจะเหมือนกัน

ที่จริงปัญหาคืออยากให้มันแยกได้อิสระ ไม่ทราบว่าจะแก้ไขยังไงดีครับ

ขอแนวทางแก้ไขหรือคำแนะนำด้วยครับ



Tag : PHP









ประวัติการแก้ไข
2013-07-13 15:19:30
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2013-07-13 15:08:32 By : asustak View : 682 Reply : 8
 

 

No. 1



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

ลองดูตัวอย่างนี้ครับ



การนำ jQuery มาทำ AutoFill ข้อมูล Textbox และการตรวจสอบข้อมูลซ้ำด้วย Ajax







แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-07-13 15:46:18 By : mr.win
 


 

No. 2



โพสกระทู้ ( 283 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

Code (PHP)
<html>
<head>
<title>ThaiCreate.Com</title>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script type="text/javascript">
$(document).ready(function(){

		$('input[name*="txtCustomerID"]').change("change", function (){
			var currentIndex = $(this).closest("tr")[0].rowIndex;

			$.ajax({ 
				url: "returnCustomer3.php" ,
				type: "POST",
				data: 'sCusID=' +$("#txtCustomerID"+currentIndex).val()
			})
			.success(function(result) { 
				var obj = jQuery.parseJSON(result);
				
					if(obj == '')
					{
					   $("#txtCustomerID"+currentIndex).val('');
					   $("#txtName"+currentIndex).val('');
					   $("#txtEmail"+currentIndex).val('');
					   $("#txtCountryCode"+currentIndex).val('');
					   $("#txtBudget"+currentIndex).val('');
					   $("#txtUsed"+currentIndex).val('');
					}
					else
					{
					  $.each(obj, function(key, inval) {

						   $("#txtCustomerID"+currentIndex).val(inval["CustomerID"]);
						   $("#txtName"+currentIndex).val(inval["Name"]);
						   $("#txtEmail"+currentIndex).val(inval["Email"]);
						   $("#txtCountryCode"+currentIndex).val(inval["CountryCode"]);
						   $("#txtBudget"+currentIndex).val(inval["Budget"]);
						   $("#txtUsed"+currentIndex).val(inval["Used"]);

					  });
					}

				});


		});

	
	});
</script>
</head>
<body>
<h2>jQuery Auto fill ดึงข้อมูลอัตโนมัติ แบบตารางหลายแถว</h2>
<form action="phpMySQLAddSave.php" name="frmAdd" method="post">
<table width="600" border="1">
  <tr>
    <th width="91"> <div align="center">CustomerID </div></th>
    <th width="160"> <div align="center">Name </div></th>
    <th width="198"> <div align="center">Email </div></th>
    <th width="97"> <div align="center">CountryCode </div></th>
    <th width="70"> <div align="center">Budget </div></th>
    <th width="70"> <div align="center">Used </div></th>
  </tr>
  <?
  for($i=1;$i<=10;$i++)
  {
  ?>
  <tr>
    <td><div align="center"><input type="text" name="txtCustomerID<?=$i;?>"  id="txtCustomerID<?=$i;?>" size="5"></div></td>
    <td><input type="text" name="txtName<?=$i;?>"  id="txtName<?=$i;?>" size="20"></td>
    <td><input type="text" name="txtEmail<?=$i;?>" id="txtEmail<?=$i;?>" size="25"></td>
    <td><div align="center"><input type="text" name="txtCountryCode<?=$i;?>" id="txtCountryCode<?=$i;?>" size="2"></div></td>
    <td align="right"><input type="text" name="txtBudget<?=$i;?>" id="txtBudget<?=$i;?>" size="5"></td>
    <td align="right"><input type="text" name="txtUsed<?=$i;?>" id="txtUsed<?=$i;?>" size="5"></td>
  </tr>
  <?
  }
  ?>
  </table>
<input type="hidden" name="hdnLine" value="<?=$i;?>">
</form>
</body>
</html>




ตัวนี้ใช่ไหมครับพี่วิน เดี๋ยวจลองแกะ code ดู แนวทางคราวๆเหมือนกับสร้าง index ให้แต่ละ id เพื่อนำค่าไปอ้างอิง

ผมเข้าใจถูกป่าวหว่า
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-07-13 16:05:08 By : asustak
 

 

No. 3



โพสกระทู้ ( 283 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

ยังไม่ได้เลย T_T
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-07-13 21:02:30 By : asustak
 


 

No. 4



โพสกระทู้ ( 283 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

เพิ่มเติมครับพอดีผมใช้
Code (PHP)
	 $('.name_material').live("change", function(){

			url = 'ajax_material.php',
		  $.post(url,
			{ mat_list: $(this).val()},
			   
		  function(data)
		  {
				 if(data.success)
				 {
						  $('#type_unit').val(data.message);
						  $('.mat_list').val(data.mat_code);	  
				 }
		  },'json');
		return false;	  				
			
	 }); 


var removeLink = ' <a class="remove" href="#" onclick="$(this).parent().slideUp(function(){ $(this).remove() }); return false">ลบ</a>';

$('a.add').relCopy({ append: removeLink}); 	


แทนการ while ครับ

โดย จะมีปุ่ม + เพื่อ Clone


Code (PHP)
            <div class="clone" style="margin-top:10px">          
            <p>
            <label>ชื่อวัตถุดิบ <span class="require">*</span>:</label>
             <select name="name_material[]" id="name_material" class="name_material">
              <option value="">-- เลือกวัตถุดิบ --</option>
              <?
				  $qry_list = mysql_query("select mat_code, mat_name from material where mat_status='1'");
				  while($arr_list=mysql_fetch_array($qry_list))
				  {
					  echo "<option value='".$arr_list['mat_code']."'>".$arr_list['mat_name']."</option>";
				  }
				   ?>
            </select>                 
          </p>              
          <p>
           	<label>รหัสวัตถุดิบ <span class="require">*</span>:</label>
            	<input name="mat_list[]" type="text" id="mat_list" class="mat_list" readonly="readonly" />
          </p>                         
          <p>
            <label>จำนวน <span class="require">*</span>:</label>
              <input type="text" name="qty[]" id="qty" />
          </p>  
          <a href="#" class="add" rel=".clone" style="margin-left:150px;">+ เพิ่มวัตถุดิบที่เบิก</a>
            
           </div>           



ตอนนี้ยังงงอยู่เลยครับ ช่วยหน่อยครับ


เมื่อลองจาก code แล้ว ค่าในส่วนของ <input name="mat_list[]" type="text" id="mat_list" class="mat_list" readonly="readonly" /> จะเปลี่ยนตามกันหมดทุกช่อง


ลอง view source แล้ว เมื่อ clone ได้แล้ว ค่า mat_list ตัวต่อไปจะมีค่าเป็น mat_list2



ผมต้องการนำค่า mat_list2 มาแทน ในส่วนของ

Code (PHP)
				 if(data.success)
				 {
						  $('#type_unit').val(data.message);
						  $('.mat_list').val(data.mat_code);	  
				 }


$('.mat_list').val(data.mat_code); << แทนตัวนี้ เพื่อให้ค่าแต่ละ class แยกกันได้อิสระ



นั่งงงตั้งนาน ลอง search ข้อมูลดูแต่ยังไม่ค่อยเข้าใจเท่าไรครับ เกี่ยวกับการนำ .closet มาใช้งาน


ประวัติการแก้ไข
2013-07-13 22:30:16
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-07-13 22:24:48 By : asustak
 


 

No. 5



โพสกระทู้ ( 1,521 )
บทความ ( 2 )

สมาชิกที่ใส่เสื้อไทยครีเอท Hall of Fame 2012

สถานะออฟไลน์
Facebook

Code (PHP)
$('.mat_list').val(data.mat_code);  
//ลองเปลี่ยนเป็น
$(this).parent().parent().find('input[name="mat_list[]"]').val(data.mat_code);

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-07-13 23:03:24 By : Krungsri
 


 

No. 6



โพสกระทู้ ( 283 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

ตอบความคิดเห็นที่ : 5 เขียนโดย : Krungsri เมื่อวันที่ 2013-07-13 23:03:24
รายละเอียดของการตอบ ::
ลองแล้วครับ แต่ val() ไม่แสดงครับ




แต่ลองนำ

	 $('.name_material').live("change", function(){

		alert($(this).parent().parent().find('input[name="mat_list[]"]').attr("id"));
		
			url = 'ajax_material.php',
		  $.post(url,
			{ mat_list: $(this).val()},
			   
		  function(data)
		  {
				 if(data.success)
				 {

						  $('#type_unit').val(data.message);
						  $(this).parent().parent().find('input[name="mat_list[]"]').val(data.mat_code);
						  

				 }
		  },'json');
		return false;	  				
				
	 });  	

alert($(this).parent().parent().find('input[name="mat_list[]"]').attr("id"));  ตัวนี้จะ alert ค่าได้  ส่วนตัวที่อยู่ใน

				 if(data.success)
				 {

						  $('#type_unit').val(data.message);
						  $(this).parent().parent().find('input[name="mat_list[]"]').val(data.mat_code);
						  

				 }


จะไม่มีค่าครับ


ประวัติการแก้ไข
2013-07-13 23:18:39
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-07-13 23:11:28 By : asustak
 


 

No. 7



โพสกระทู้ ( 283 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

ตอนนี้ได้แล้วครับ

ขอบคุณมากครับ


Code (PHP)
	 $('.name_material').live("change", function(){

		//alert($(this).parent().parent().find('input[name="mat_list[]"]').attr("id"));
		var t = $(this).parent().parent().find('input[name="mat_list[]"]').attr("id");
			url = 'ajax_material.php',
		  $.post(url,
			{ mat_list: $(this).val()},
			   
		  function(data)
		  {
				 if(data.success)
				 {

						  $('#type_unit').val(data.message);
						  $('#'+t+'').val(data.mat_code);
						  alert(t);

				 }
		  },'json');
		return false;	  				
				
	 });  	

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-07-13 23:23:57 By : asustak
 


 

No. 8



โพสกระทู้ ( 1,521 )
บทความ ( 2 )

สมาชิกที่ใส่เสื้อไทยครีเอท Hall of Fame 2012

สถานะออฟไลน์
Facebook


เพิ่มเติมครับเผื่อได้
$('.name_material').live("change", function(){
		var Owner = $(this).parent().parent();
		url = 'ajax_material.php',
		$.post(url,
			{ mat_list: $(this).val()},
			   
		  function(data)
		  {
				 if(data.success)
				 {
						  $('#type_unit').val(data.message);
						  Owner.find('input[name="mat_list[]"]').val(data.mat_code);  
				 }
		  },'json');
		return false;	  					
	 }); 

แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2013-07-13 23:29:07 By : Krungsri
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : ขอปรึกษาเกี่ยวกับการส่งมามาแสดงผลของ ajax ให้ไปแสดงผลในส่วนของ array หน่อยครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 00
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่