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

Registered : 104,082

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




 

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
SVN : การ Add New , Edit , Commit ,Update , Delete ไฟล์บน SVN Server
SVN : การ Add New , Edit , Commit ,Update , Delete ไฟล์บน SVN Server
ในหัวข้อนี้เราจะมาเริ่มต้นพื้นฐานการใช้ SVN Client เพื่อจัดการ Resource และไฟล์ต่าง ๆ จาก SVN Server ซึ่งโดยปกติแล้วฟีเจอร์ที่เราใช้กันทั่ว ๆ ไป คือการ Add ไฟล์ , Edit ไฟล์ และ Delete ไฟล์ จาก Client ระหว่าง Server
Rating : Update : 2015-11-19 12:56:47
VB.Net ป้องกันการบันทึก (Insert) ข้อมูลซ้ำ
VB.Net ป้องกันการบันทึก (Insert) ข้อมูลซ้ำ
โค้ดตรวรจสอบข้อมูลก่อนการบันทึก เพื่อป้องกันบันทึกข้อมูลซ้ำลงในฐานข้อมูล
Rating : Update : 2017-02-15 11:11:23
iOS 10 ออกมาให้อัพเดดบน iPhone, iPad , และอุปกรณ์อื่น ๆ จากค่าย Apple
iOS 10 ออกมาให้อัพเดดบน iPhone, iPad , และอุปกรณ์อื่น ๆ จากค่าย Apple
ในวันนี้ 14-15 Sep 2016 ทางค่าย Apple ได้ทำการปล่อย iOS 10 Release ออกมาให้สาวกที่มช้อุปกรณ์ ในของบริษัท Apple ได้ดาวน์โหลดและอัพเดดกันแล้ว
Rating : Update : 2017-03-18 23:21:18
เขียน PHP แบบ Heredoc ช่วยให้การเขียน PHP กับ HTML ง่ายและสะดวกมาก
เขียน PHP แบบ Heredoc ช่วยให้การเขียน PHP กับ HTML ง่ายและสะดวกมาก
ทุกวันนี้ เข้าเว็บไหนๆ ก็จะเห็นเป็น https หมดแล้ว เนื่องด้วยการประกาศจากทาง Google ซึ่งมีผลกับอันดับและเรื่องความปลอดภัยอีกด้วย
Rating : Update : 2017-04-17 06:41:36
C# การใช้งาน DataTable กับ DataGridView (MS Access 2007) แบบบ้านๆ
C# การใช้งาน DataTable กับ DataGridView (MS Access 2007) แบบบ้านๆ
บทความนี้จะกล่าวถึง การใช้งาน datatable กับ DataGridView (Access 2007) แบบบ้านๆ หลังจากที่ผมใช้งาน DataSource Wizard กับ DataGridView (Access 2007)ได้แล้ว
Rating : Update : 2015-10-02 21:11:27
แจกระบบ PHP Shopping Cart ระบบตะกร้าสินค้า ระบบสั่งซื้อ มีระบบตัดสต๊อก, สั่งซื้อวัตถุดิบคงเหลือ
แจกระบบ PHP Shopping Cart ระบบตะกร้าสินค้า ระบบสั่งซื้อ มีระบบตัดสต๊อก, สั่งซื้อวัตถุดิบคงเหลือ
เป็นโปรเจคเก่าๆ สมัยปี 2007-2008 เกี่ยวกับระบบ php shopping cart มีระบบสั่งซื้อสินค้า ตัด Stock เมื่อสินค้าถูกสั่งซื้อไปแล้ว รวมทั้งระบบจัดการวัตถุดิบ
Rating : Update : 2017-03-30 14:04:45
ตอนที่ 1 : ดาวน์โหลดและติดตั้ง Database Oracle 11g ฟรี จากเว็บไซต์ของ Oracle
ตอนที่ 1 : ดาวน์โหลดและติดตั้ง Database Oracle 11g ฟรี จากเว็บไซต์ของ Oracle
ห่างหายไปจากบทความ Oracle Database ไปนานพอสมควร ได้มีโอกาศมาเริ่มจับมันอีกครั้ง พร้อม ๆ กับจะพยายามเขียนบทความ ในรูปแบบเทคนิคการใช้งานขั้นสูงขึ้น ในคงามตั้งใจแต่แรกคือต้องการ สอนการเขียน Stored Procedure อย่างเดียว
Rating : Update : 2016-02-02 09:00:41
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-2017 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 08-9968-0655 อัตราราคา คลิกที่นี่