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,786

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
บทความสำหรับการทำ Login ผ่าน Facebook API ในรูปแบบต่างๆ (Facebook for Developers)
บทความสำหรับการทำ Login ผ่าน Facebook API ในรูปแบบต่างๆ (Facebook for Developers)
หัวข้อนี้จะเป็นการรวบรวมบทความของไทยครีเอทที่เกี่ยวข้องกับ Facebook API การทำระบบ Login ของเว็บ เพื่อเชื่อมต่อกับ Facebook Account และการเชื่อมต่อกับ MySQL ระบบสมาชิกของเว็บ ซึ่งเป็นวิธีการที่ทำให้เว็บได้รับความสนใจจากสมาชิก เพราะสามารถ Login ง่ายโดยไม่ต้องจดจำรหัสผ่านต่างๆ
Rating : Update : 2017-04-13 23:03:03
VB.Net,C# Send Mail ส่งอีเมล์ และการส่งผ่าน SMTP ด้วย System.Net.Mail
VB.Net,C# Send Mail ส่งอีเมล์ และการส่งผ่าน SMTP ด้วย System.Net.Mail
บทความและตัวอย่างการส่งอีเมล์ (Mail) ด้วยบน .Net Application ซึ่งสามารถใช้ได้กับทุกๆ Application ที่พัฒนาด้วย .Net Framework โดยใช้ Library ของ System.Net.Mail
Rating : Update : 2017-04-01 07:18:10
วิธีเปลี่ยนเว็บไซต์ให้แสดงเป็น ขาว-ดำ เพื่อรวมไว้อาลัยกับการสวรรคตของ  ในหลวง รัชกาลที่ ๙
วิธีเปลี่ยนเว็บไซต์ให้แสดงเป็น ขาว-ดำ เพื่อรวมไว้อาลัยกับการสวรรคตของ ในหลวง รัชกาลที่ ๙
วิธีเปลี่ยนเว็บไซต์ให้แสดงเป็น ขาว-ดำ เพื่อรวมไว้อาลัยกับการสวรรคตของ "ในหลวง" รัชกาลที่ ๙
Rating : Update : 2017-03-18 23:09:40
การสร้าง Event Scheduler  หรือ Job Schedule บน MySQL/MariaDB ตั้งเวลาทำงาน
การสร้าง Event Scheduler หรือ Job Schedule บน MySQL/MariaDB ตั้งเวลาทำงาน
การเขียน event หรือ job schedule บน mysql และ mariadb เพื่อให้ทำงานตามระยะเวลาที่กำหนด เหมาะสำหรับใช้ในการสร้าง job งงานต่างๆ เช่น backup รายการ clear ข้อมูลต่างๆ
Rating : Update : 2017-03-24 17:35:11
PHP สอนใช้งาน Tinymce + filemanager Text Editor PHP
PHP สอนใช้งาน Tinymce + filemanager Text Editor PHP
บทความนี้จะมาสอนการใช้งาน textarea editor กันนะครับ โดยจะใช้ Tinymce + Feature filemanager ไว้ใช้สำหรับจัดการ ไฟล์ต่าง ๆหรือรูปภาพต่าง ๆใช้สำหรับ ภายในเว็บไซต์ นั่นเอง ผู้เขียน : Prapat Polchan
Rating : Update : 2016-07-29 16:52:35
โปรแกรม Copy file from server to pc(share file) By Itechs
โปรแกรม Copy file from server to pc(share file) By Itechs
LINK: https://drive.google.com/file/d/0B9WBIvRSivz9b08xU2R3eE1Cc0E/view?usp=sharing
Rating : Update : 2016-02-02 15:06:29
WebSocket คืออะไร??? วิธีการรับส่งข้อมูลแบบ real time ด้วย php
WebSocket คืออะไร??? วิธีการรับส่งข้อมูลแบบ real time ด้วย php

Rating : Update : 2017-01-26 16:22: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-2018 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 08-9968-0655 อัตราราคา คลิกที่นี่