zoukankan      html  css  js  c++  java
  • JS本地存储信息的实现方式(localStorage 与 userData)

    详细介绍请看:

    http://www.cnblogs.com/beiyuu/archive/2011/07/20/js-localstorage-userdata.html

    里面涉及到的 demo 代码如下:

    <script type="text/javascript">
    (function() {
    	window.localData = {
    		hname : location.hostname ? location.hostname : 'localStatus',
    		isLocalStorage : window.localStorage ? true : false,
    		dataDom : null,
    		initDom : function() {
    			if (!this.dataDom) {
    				try {
    					this.dataDom = document.createElement('input');
    					this.dataDom.type = 'hidden';
    					this.dataDom.style.display = "none";
    					this.dataDom.addBehavior('#default#userData');
    					document.body.appendChild(this.dataDom);
    					var exDate = new Date();
    					exDate = exDate.getDate() + 30;
    					this.dataDom.expires = exDate.toUTCString();
    				} catch (ex) {
    					return false;
    				}
    			}
    			return true;
    		},
    		set : function(key, value) {
    			if (this.isLocalStorage) {
    				window.localStorage.setItem(key, value);
    			} else {
    				if (this.initDom()) {
    					this.dataDom.load(this.hname);
    					this.dataDom.setAttribute(key, value);
    					this.dataDom.save(this.hname)
    				}
    			}
    		},
    		get : function(key) {
    			if (this.isLocalStorage) {
    				return window.localStorage.getItem(key);
    			} else {
    				if (this.initDom()) {
    					this.dataDom.load(this.hname);
    					return this.dataDom.getAttribute(key);
    				}
    			}
    		},
    		remove : function(key) {
    			if (this.isLocalStorage) {
    				localStorage.removeItem(key);
    			} else {
    				if (this.initDom()) {
    					this.dataDom.load(this.hname);
    					this.dataDom.removeAttribute(key);
    					this.dataDom.save(this.hname)
    				}
    			}
    		}
    	};
    
    	var text = document.getElementById('localDataHook');
    	var btn = document.getElementById('clearBtnHook');
    	window.onbeforeunload = function() {
    		localData.set('beiyuuData', text.value);
    	};
    
    	btn.onclick = function() {
    		localData.remove('beiyuuData');
    		text.value = ''
    	};
    
    	if (localData.get('beiyuuData')) {
    		text.value = localData.get('beiyuuData');
    	}
    })();
    </script>

    还有一个比较实用的技术,阻止页面关闭,显示 关闭页面确认弹出框,参考代码如下:

    window.onbeforeunload = function() {
    	if (!canLeavePage()) {
    		return ('确认离开当前页面吗?未保存的数据将会丢失!');
    	}
    };
    
  • 相关阅读:
    pycharm下载与安装
    IOS 字体表
    iOS 在 ARC 环境下 dealloc 的使用、理解误区
    微信支付的开发
    Undefined symbols for architecture i386:和"_OBJC_CLASS_$_xx", referenced from:问题解决方法
    soureTree使用
    UINavigationController 直接pop到指定controllerView的方法
    OBC: NSString 与 NSArray 互转
    NSArray的containsObject的使用时注意的问题
    IOS 自定义导航栏标题和返回按钮标题
  • 原文地址:https://www.cnblogs.com/52php/p/6285307.html
Copyright © 2011-2022 走看看