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

Registered : 103,251

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
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
.Net Application ใช้ DateTime รูปแบบวันที่ให้ถูกต้องตาม Format ของ พ.ศ หรือ ค.ศ  (Culture)
.Net Application ใช้ DateTime รูปแบบวันที่ให้ถูกต้องตาม Format ของ พ.ศ หรือ ค.ศ (Culture)
บทความแนะนำการใช้ DateTime บน .Net Application ให้ถูกต้องตาม Format ของ Culture ที่อยู่ในรูปแบบของ พ.ศ และ ค.ศ ซึ่งโปรแกรมเมอร์ใช้กันถูกๆ ผิดๆ กันอยู่มาก
Rating : Update : 2017-03-30 08:27:33
Facebook Login Api ด้วย JavaScript SDK/PHP และการจัดเก็บใน MySQL (Update 2017)
Facebook Login Api ด้วย JavaScript SDK/PHP และการจัดเก็บใน MySQL (Update 2017)
บทความนี้จะเป็นการสอนการทำระบบ Login ด้วย Facebook Account ด้วย Facebook API ที่เขียนด้วย JavaScript และการทำงานร่วมกับ PHP รวมทั้งการจัดเก็บลงใน MySQL Database ด้วย
Rating : Update : 2017-04-08 09:01:30
เชิญชวนเว็บมาสเตอร์ติด ริปปิ้นดำ (ribbon) ตรง มุม บนซ้าย,บนขวา,ล่างซ้าย,ล่างขวา ของเว็บไซต์
เชิญชวนเว็บมาสเตอร์ติด ริปปิ้นดำ (ribbon) ตรง มุม บนซ้าย,บนขวา,ล่างซ้าย,ล่างขวา ของเว็บไซต์
เนื่องจากภายในปีนี้จะมีการ พิธีถวายพระเพลิงพระบรมศพ พระบาทสมเด็จพระปรมินทรมหาภูมิพลอดุลยเดช (ในหลวงรัชกาลที่ ๙) เชิญชวนทุกท่านติดริปปิ้นดำ เพื่อร่วมไว้อาลัย น้อมส่งเสด็จ สู่สวรรคาลัย
Rating : Update : 2017-03-24 17:41:50
โค้ดเราอ่านได้ง่ายแล้วหรือยัง?
โค้ดเราอ่านได้ง่ายแล้วหรือยัง?
หลายๆคนก็คงประสบปัญหาเดียวกัน คือ การที่เราต้องไปแก้โค้ดคนอื่นที่เขียนไว้ หรือ กลับมาอ่านโค้ดตัวเองในภายหลัง ต้องใช้เวลาอย่างมาก เลยจะมีวลีเด็ดที่ว่า "เขียนใหม่ง่ายกว่า"
Rating : Update : 2017-01-19 21:00:25
Windows Form App : การทำ ProgressBar แบบ Dialog ทำงานร่วมกับ BackgroundWorker (VB.Net, C#)
Windows Form App : การทำ ProgressBar แบบ Dialog ทำงานร่วมกับ BackgroundWorker (VB.Net, C#)
จะเป็นการประยุกต์ใช้งานร่วมกับ ProgressBar และ Dailog ซึ่ง Interface นี้จะเหมาะกับโปรแกรมที่ทำงานนานพอสมควร และป้องกันในขณะที่โปรแกรมกำลังทำงาน ต้องการไม่ให้ User ทำการคลิกที่ส่วนอื่น ๆ ของหน้าจอ
Rating : Update : 2017-03-25 13:27:13
ติดตั้ง xampp 5.5.24 เพื่อใช้เขียน PHP 5.5 (รันคู่กับ wampp หรือ appserv ได้นะครับ)
ติดตั้ง xampp 5.5.24 เพื่อใช้เขียน PHP 5.5 (รันคู่กับ wampp หรือ appserv ได้นะครับ)
เราจะใช้แพกเกจจากเว็บไซต์ Apache FriendsXAMPP : Apache + MySQL + PHP + Perl โดยรุ่นที่จะใช้งานคือต้องมี PHP 5.5 ซึ่งรุ่นที่มียอดดาวน์โหลดมากที่สุดก็คือ xampp 5.5.24 และเพื่อความสะดวกสำหรับการใช้งานหลายเวอร์ชั่น ผมจึงดาวน์โหลดรุ่นที่เป็น Portable ให้เลือกที่ xampp-portable-win32-5.5.24-0-VC11 (ซึ่งมียอดดาวน์โหลดมากที่สุดของรุ่นเดียวกัน)
Rating : Update : 2017-03-25 13:08:47
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
สอน Struts การเขียนโปรแกรม Java Struts Framework
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน Yii  Framework การเขียนโปรแกรม ภาษา PHP กับ Yii
สอน .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 01
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 , 084-715-5121 อัตราราคา คลิกที่นี่