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

Registered : 105,350

HOME > บทความจากสมาชิก > jQuery วิธี Save State Form เมื่อกด Refresh หรือ Back แล้วข้อมูลบน Form ไม่หาย


 
VPS  250 ҷ͹

jQuery วิธี Save State Form เมื่อกด Refresh หรือ Back แล้วข้อมูลบน Form ไม่หาย

jQuery วิธี Save State Form เมื่อกด Refresh หรือ Back แล้วข้อมูลบน Form ไม่หาย เห็นถามกันบ่อยๆ เกี่ยวกับเทคนิคการทำ State ของ Form โดยเมื่อเราทำการ Submit หรือกด Refresh หรือกด Back จากหน้าที่ผ่านการ Submit ให้ย้อนกลับไปแล้วค่าไม่หาย ค่าที่ยังกรอกยังอยู่ ซึ่งก่อนหน้านี้ในไทยครีเอทก็มีเทคนิคนี้อยู่บ้างแล้ว แล้วค่อนข้างจะเก่ามาก และ ตกรุ่นไปเยอะพอสมควร วันนี้มีโอกาสเลยเอาเทคนิคดีๆ แบบนี้มาแจกกัน และเชื่อว่าจะมีประโยชน์แน่นอน

jQuery Save State

jQuery Save State Form


ในบทความนี้ใช้เทคนิคที่ค่อนข้างจะทันสมัยคือ ใช้ jQuery จัดเก็บข้อมูลลงใน localStorage โดยจะเก็บข้อมูลเกือบจะ Real time เพราะทุกครั้งที่มีการ พิมพ์ข้อมูล หรือ เลือกรายการต่างๆ บน Form โปรแกรมจะจัดเก็บข้อมูลลงใน localStorage และเมื่อกด Submit แล้ว Back กลับมา หรือ Refresh หน้าเดิม โปรแกรมก็จะนำข้อมูลที่เคสจัดเก็บลงใน localStorage มาใส่ใน element ต่างๆ

function ที่ใช้จัดเก็บ State ลงใน localStorage
	//*** function
	(function ($) {
		function formsaver(method, container) {
			function getStorageId(container) {
				return 'formdata__$url__$extra'.replace('$url', location.pathname)
											   .replace('$extra', container.attr('id') || '');
			}

			var storageId = getStorageId(container),
				controller = {
					save: function () {
						this._save(storageId, this.extractValues());
					},
					restore: function () {
						this.fillFields(this._load(storageId));
					},
					clear: function () {
						this._remove(storageId);
					},

					extractValues: function () {
						var formData = container.find(":input[name]").serializeArray(),
							preparedData = {};
						$.each(formData, function (index, element) {
							var name = element.name,
								value = encodeURIComponent(element.value);
							if (preparedData[name]) {
								preparedData[name] = preparedData[name] instanceof Array ?
													 preparedData[name].concat(value) :
													 [preparedData[name], value];
							} else {
								preparedData[name] = value;
							}
						});
						return preparedData;
					},
					fillFields: function (formData) {
						$.each(formData, function (name, value) {
							var field = container.find("[name=" + name + "]"),
								inputType = field.prop('type');
							value = value instanceof Array ? value.map(decodeURIComponent) :
															 decodeURIComponent(value);
							if (inputType === 'checkbox') {
								field.attr('checked', 'checked');
							} else if (inputType === 'radio') {
								field.filter("[value=" + value + "]").prop('checked', true);
							} else {
								field.val(value);
							}
						});
					},

					_save: function (storageId, data) {
						localStorage[storageId] = JSON.stringify(data);
					},
					_load: function (storageId) {
						return localStorage[storageId] ? JSON.parse(localStorage[storageId]) : {};
					},
					_remove: function (storageId) {
						localStorage.removeItem(storageId);
					}
				},
				methodsQueue = method instanceof Array ? method : [method];

			$.each(methodsQueue, function (index, method) {
				controller[method]();
			});
		}
		$.fn.saveForm = function () {
			formsaver('save', $(this));
		};
		$.fn.restoreForm = function () {
			formsaver(['restore'], $(this));
		};
		$.fn.clearForm = function () {
			formsaver(['clear'], $(this));
		};
	})(jQuery);

เมื่อมีการคีย์ข้อมูลลงใน Form จะมีการ Save State
	$("#frmMain").on("change click", function(e) {
		$("#frmMain").saveForm();
	});

เมื่อมีการกด Back หรือ Refresh จะมีการ Restore State
	$(document).ready(function() {
		$("#frmMain").restoreForm();
	}); 

เมื่อกต้องการ Clear ค่าให้เรียก function นี้
$("#frmMain").clearForm();









Code เต็มๆ
<html>
<head>
<title>ThaiCreate.Com</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>
</head>
<body>
<form action="" method="post" name="frmMain" id="frmMain">
  <table width="480" border="0">
    <tr>
      <td width="157">Name</td>
      <td width="307"><input type="text" id="txtName" name="txtName"></td>
    </tr>
    <tr>
      <td>Email</td>
      <td><input type="text" id="txtEmail" name="txtEmail"></td>
    </tr>
    <tr>
      <td>Gender</td>
      <td><input type="radio" name="rdoGender"id="rdoGender1" value="M">
        Mail
          <input type="radio" name="rdoGender" id="rdoGender2" value="F"> 
          Female</td>
    </tr>
    <tr>
      <td>Working</td>
      <td><input type="checkbox" name="chkWorking" id="chkWorking" value="Y"></td>
    </tr>
    <tr>
      <td>Address</td>
      <td><textarea name="txtAddress" id="txtAddress" cols="40" rows="5"></textarea></td>
    </tr>
    <tr>
      <td>Country</td>
      <td><select name="ddlCountry" id="ddlCountry">
        <option value="-">-- Country --</option>
        <option value="TH">Thailand</option>
        <option value="US">United States</option>
      </select></td>
    </tr>
    <tr>
      <td>&nbsp;</td>
      <td>&nbsp;</td>
    </tr>
  </table>
<input type="submit" name="Submit" value="Submit">
<input type="button" name="btnClear" id="btnClear" value="Clear">
</form>

<script type="text/javascript">

	//*** function
	(function ($) {
		function formsaver(method, container) {
			function getStorageId(container) {
				return 'formdata__$url__$extra'.replace('$url', location.pathname)
											   .replace('$extra', container.attr('id') || '');
			}

			var storageId = getStorageId(container),
				controller = {
					save: function () {
						this._save(storageId, this.extractValues());
					},
					restore: function () {
						this.fillFields(this._load(storageId));
					},
					clear: function () {
						this._remove(storageId);
					},

					extractValues: function () {
						var formData = container.find(":input[name]").serializeArray(),
							preparedData = {};
						$.each(formData, function (index, element) {
							var name = element.name,
								value = encodeURIComponent(element.value);
							if (preparedData[name]) {
								preparedData[name] = preparedData[name] instanceof Array ?
													 preparedData[name].concat(value) :
													 [preparedData[name], value];
							} else {
								preparedData[name] = value;
							}
						});
						return preparedData;
					},
					fillFields: function (formData) {
						$.each(formData, function (name, value) {
							var field = container.find("[name=" + name + "]"),
								inputType = field.prop('type');
							value = value instanceof Array ? value.map(decodeURIComponent) :
															 decodeURIComponent(value);
							if (inputType === 'checkbox') {
								field.attr('checked', 'checked');
							} else if (inputType === 'radio') {
								field.filter("[value=" + value + "]").prop('checked', true);
							} else {
								field.val(value);
							}
						});
					},

					_save: function (storageId, data) {
						localStorage[storageId] = JSON.stringify(data);
					},
					_load: function (storageId) {
						return localStorage[storageId] ? JSON.parse(localStorage[storageId]) : {};
					},
					_remove: function (storageId) {
						localStorage.removeItem(storageId);
					}
				},
				methodsQueue = method instanceof Array ? method : [method];

			$.each(methodsQueue, function (index, method) {
				controller[method]();
			});
		}
		$.fn.saveForm = function () {
			formsaver('save', $(this));
		};
		$.fn.restoreForm = function () {
			formsaver(['restore'], $(this));
		};
		$.fn.clearForm = function () {
			formsaver(['clear'], $(this));
		};
	})(jQuery);

	//*** restore after refresh
	$(document).ready(function() {
		$("#frmMain").restoreForm();
	}); 
	
	//*** save form
	$("#frmMain").on("change click", function(e) {
		$("#frmMain").saveForm();
	});
	

	//*** clear form
	//$("#frmMain").clearForm();
</script>
</body>
</html>









ทดสอบการทำงาน

jQuery Save State

ทดสอบคีย์ข้อมูล แล้วให้กด Refresh

jQuery Save State

จะเห็นว่าข้อมูลยังอยู่เหมือนเดิม

เพิ่มเติม สามารถแยกเป็นไฟล์ js เพราะจะสามารถเรียกได้ในทุกๆ หน้าได้ง่ายและสะดวกขึ้น

savestate.js
	//*** function
	(function ($) {
		function formsaver(method, container) {
			function getStorageId(container) {
				return 'formdata__$url__$extra'.replace('$url', location.pathname)
											   .replace('$extra', container.attr('id') || '');
			}

			var storageId = getStorageId(container),
				controller = {
					save: function () {
						this._save(storageId, this.extractValues());
					},
					restore: function () {
						this.fillFields(this._load(storageId));
					},
					clear: function () {
						this._remove(storageId);
					},

					extractValues: function () {
						var formData = container.find(":input[name]").serializeArray(),
							preparedData = {};
						$.each(formData, function (index, element) {
							var name = element.name,
								value = encodeURIComponent(element.value);
							if (preparedData[name]) {
								preparedData[name] = preparedData[name] instanceof Array ?
													 preparedData[name].concat(value) :
													 [preparedData[name], value];
							} else {
								preparedData[name] = value;
							}
						});
						return preparedData;
					},
					fillFields: function (formData) {
						$.each(formData, function (name, value) {
							var field = container.find("[name=" + name + "]"),
								inputType = field.prop('type');
							value = value instanceof Array ? value.map(decodeURIComponent) :
															 decodeURIComponent(value);
							if (inputType === 'checkbox') {
								field.attr('checked', 'checked');
							} else if (inputType === 'radio') {
								field.filter("[value=" + value + "]").prop('checked', true);
							} else {
								field.val(value);
							}
						});
					},

					_save: function (storageId, data) {
						localStorage[storageId] = JSON.stringify(data);
					},
					_load: function (storageId) {
						return localStorage[storageId] ? JSON.parse(localStorage[storageId]) : {};
					},
					_remove: function (storageId) {
						localStorage.removeItem(storageId);
					}
				},
				methodsQueue = method instanceof Array ? method : [method];

			$.each(methodsQueue, function (index, method) {
				controller[method]();
			});
		}
		$.fn.saveForm = function () {
			formsaver('save', $(this));
		};
		$.fn.restoreForm = function () {
			formsaver(['restore'], $(this));
		};
		$.fn.clearForm = function () {
			formsaver(['clear'], $(this));
		};
	})(jQuery);


ตอนที่เรียกใช้งานจะเหลือแค่

<html>
<head>
<title>ThaiCreate.Com</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>
<script type="text/javascript" src="savestate.js"></script>
</head>
<body>


<script type="text/javascript">
	//*** restore after refresh
	$(document).ready(function() {
		$("#frmMain").restoreForm();
	}); 
	
	//*** save form
	$("#frmMain").on("change click", function(e) {
		$("#frmMain").saveForm();
	});
	

	//*** clear form
	//$("#frmMain").clearForm();
</script>


   
Share
Bookmark.   

  By : TC Admin
  Article : บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ
  Score Rating :
  Create Date : 2017-01-27
  Download : No files
Sponsored Links
เพิ่มเนื้อที่บน iPhone/iOS แบบง่าย ๆ แต่ใช้งานได้จริง ๆ (ได้คืนมา 300-2000 MB)
เพิ่มเนื้อที่บน iPhone/iOS แบบง่าย ๆ แต่ใช้งานได้จริง ๆ (ได้คืนมา 300-2000 MB)
admin เป็นคนหนึ่งที่ใช้ iPhone 16 G ซึ่งตอนแรกก็คิดว่าน่าจะเหลือเฟือ แต่พอใช้มาได้ 2 ปี ตอนนี้เริ่มไม่พอซะล่ะ
Rating : Update : 2017-03-18 23:10:25
C# การสร้างฐานข้อมูลลูกค้าด้วย DataGridView แบบ บ้านๆ โดยใช้  DataSource Wizard
C# การสร้างฐานข้อมูลลูกค้าด้วย DataGridView แบบ บ้านๆ โดยใช้ DataSource Wizard
C# การสร้างฐานข้อมูลลูกค้าด้วย datagridview แบบ บ้านๆ โดยใช้ DataSource Wizard
Rating : Update : 2016-06-02 15:05:07
อัพโหลดไฟล์รูป จัดเก็บชื่อในฐานข้อมูล โดย mysqli class จากนั้นนำภาพมาแสดงเป็นสไลด์ แบบ Responsive โดยใช้ Bxslider
อัพโหลดไฟล์รูป จัดเก็บชื่อในฐานข้อมูล โดย mysqli class จากนั้นนำภาพมาแสดงเป็นสไลด์ แบบ Responsive โดยใช้ Bxslider
ระบบอัพโหลดรูปภาพ ส่งข้อมูลไปบันทึกในฐานข้อมูล มีการเปิด-ปิดใช้งานรูปภาพ มีการจัดลำดับของสไลด์ ใช้ Bootstrap ส่งข้อมูลโดยใช้ jquery มีระบบล็อกอิน มีการใช้งานสไลด์ที่รองรับ responsive
Rating : Update : 2017-04-12 20:43:34
เรามาใช้ Line Notify กันดีกว่า ด้วยการใช้ PHP ง่ายๆ และใช้งานได้ดี
เรามาใช้ Line Notify กันดีกว่า ด้วยการใช้ PHP ง่ายๆ และใช้งานได้ดี
การส่ง LINE เข้ากลุ่มโดยใช้ Line Notify ด้วย PHP แบบง่ายๆ
Rating : Update : 2017-06-23 08:28:13
ASP.Net กับ reCAPTCHA ป้องกัน Spam bot ไม่ให้รุกรานเว็บไซต์ (VB.Net,C#)
ASP.Net กับ reCAPTCHA ป้องกัน Spam bot ไม่ให้รุกรานเว็บไซต์ (VB.Net,C#)
วิธีการใช้ ASP.Net กับ reCAPTCHA เพื่อป้องกัน Spam bot เข้ามารุกรานเว็บไซต์ด้วยการโพสข้อความที่เป็น Spam
Rating : Update : 2017-03-24 17:39:05
PHP การใช้งาน Graph API Facebook Notifications With Javascript sdk
PHP การใช้งาน Graph API Facebook Notifications With Javascript sdk
การใช้งาน Graph API Facebook ในส่วนของการ Notification หรือการแจ้งเตือน ด้วย Javascript sdk อย่างง่าย
Rating : Update : 2016-07-22 21:29:51
ตรวจสอบ Login จำนวนครั้งที่ผิด การแบนเวลา Login ด้วย PHP กับ MySqli (mysqli)
ตรวจสอบ Login จำนวนครั้งที่ผิด การแบนเวลา Login ด้วย PHP กับ MySqli (mysqli)
การทำระบบ Login ด้วย php กับ mysql (mysqli) และการตรวจสอบจำนวนครั้งที่ Login ผิด รวมทั้งวิธีการ Lock Account เมื่อ Login เกินจำนวนครั้ง การแบน การกำหนดระยะเวลาที่แบน
Rating : Update : 2017-03-24 17:41:11
ThaiCreate.Com Forum


Comunity Forum Free Web Script
Jobs Freelance Free Uploads
Free Web Hosting Free Tools

สอน PHP ผ่าน Youtube ฟรี
สอน Android การเขียนโปรแกรม Android
สอน Windows Phone การเขียนโปรแกรม Windows Phone 7 และ 8
สอน iOS การเขียนโปรแกรม iPhone, iPad
สอน Java การเขียนโปรแกรม ภาษา Java
สอน Java GUI การเขียนโปรแกรม ภาษา Java GUI
สอน JSP การเขียนโปรแกรม ภาษา Java
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน .Net การเขียนโปรแกรม ภาษา .Net
Free Tutorial
สอน Google Maps Api
สอน Windows Service
สอน Entity Framework
สอน Android
สอน Java เขียน Java
Java GUI Swing
สอน JSP (Web App)
iOS (iPhone,iPad)
Windows Phone
Windows Azure
Windows Store
Laravel Framework
Yii PHP Framework
สอน jQuery
สอน jQuery กับ Ajax
สอน PHP OOP (Vdo)
Ajax Tutorials
SQL Tutorials
สอน SQL (Part 2)
JavaScript Tutorial
Javascript Tips
VBScript Tutorial
VBScript Validation
Microsoft Access
MySQL Tutorials
-- Stored Procedure
MariaDB Database
SQL Server Tutorial
SQL Server 2005
SQL Server 2008
SQL Server 2012
-- Stored Procedure
Oracle Database
-- Stored Procedure
SVN (Subversion)
แนวทางการทำ SEO
ปรับแต่งเว็บให้โหลดเร็ว


สุดยอด Source Code V2.0
 

แจ้งชำระเงิน/โอนเงิน
 

Hit Link
   


Acc : thaicreate@hotmail.com




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