jQuery写缓存之:sessionStorage的运用,配合PHP将不同tab页的数据写入后台
JS(jQuery)写缓存之:sessionStorage的运用:
结果就是讲存储的DOM对象value传到后台PHP,进行foreach(){} 解析JSON成二维数组
示例页面:http://www.xxxx.com/index.php?ctl=project&act=add_content&id=63
图片:
上1和下2

/*我的自述 我的项目 为何众筹 + 自定义章节 */
/*我的自述 我的项目 为何众筹 + 自定义章节 */
$(function(){
$('ul#tab li').bind("mousedown",function(){
/*点击叠加样式*/
$(this).addClass('active').siblings().removeClass('active');
});
js_session_mouseup();
//点击this自定义章节,siblings()上下排序、删除div自动隐藏
click_custom_hide(); $("ul#tab li").bind("mousedown",function(){
var index3 = $(this).index();
if(index3 >= 3){
$(this).addClass("active").siblings().removeClass("active"); //加样式
$("#kw").removeAttr("readonly");
// //给#kw初始化赋值
// var val = $(this).text();
// //alert(val+"id=63");
// $("#kw").val(val);
//动态给<a>赋值
$("#kw").bind("keyup",function(){
var kw = $("#kw").val();
$("li[class='active']").find("a").text(kw);
});
}else if(index3 <=2 && index3 >=0){
$("#kw").attr("readonly",true);
}
}); var i=0;
$('#addTable').bind('mouseup',function(){
++i;
//alert(i);
var count = $('ul#tab li').length;
//alert(count);
//所有章节最多只允许存在5个,通过i判断 xzz0505
if(count >= 5){
$.showErr("抱歉,自定义章节最多只允许添加2个");
return false;
}
$("#tab").append("<li><a>自定义章节</a><div class='changeIndex'> <div class='transform up'> <span class='icon icon-kaistart-arrows-left'></span> </div> <div class='transform down'> <span class='icon icon-kaistart-arrows-left'></span> </div> </div> <span class='icon icon-kaistart-close'></span></li>"); $("ul#tab li").bind("mousedown",function(){
var index2 = $(this).index();
if(index2 >= 3){
$(this).addClass("active").siblings().removeClass("active"); //加样式
$("#kw").removeAttr("readonly");
// //给#kw初始化赋值
// var val = $(this).text();
// //alert(val+"id=63");
// $("#kw").val(val);
//动态给<a>赋值
$("#kw").bind("keyup",function(){
var kw = $("#kw").val();
$("li[class='active']").find("a").text(kw);
});
}else if(index2 <=2 && index2 >=0){
$("#kw").attr("readonly",true);
}
});
js_session_mouseup();
//点击this自定义章节,siblings()上下排序、删除div自动隐藏
click_custom_hide(); /*点击‘x’自定义章节删除*/
$(document).on('click', '.icon-kaistart-close', function() {
if(!window.sessionStorage){
return false;
}else{
var del_key = $.trim($(this).parent().find("a").text())+$("input[name='id']").val().toString();
var storage = window.sessionStorage;
storage.removeItem("del_key");
}
$(this).parent().remove();
//--i;
});
});
}); function js_session_mouseup(){
if(!window.sessionStorage){
return false;
}else{
$("ul#tab li").bind("mouseup",function(){
var index = $(this).index();
var my_block = $.trim($("input[name='my_block']").val());
var my_title = $.trim($("input[name='my_title']").val());
var descript = $(".editable").html();
var textarea = $.trim($("textarea[name='descript']").val());
//表单章节名+项目id
var block_key = my_block+$("input[name='id']").val().toString();
//点击的左侧章节名+项目id
var click_key = $.trim($(this).find("a").text())+$("input[name='id']").val().toString();
//将<form>表单存储为json对象,以‘章节名+项目id’为key,三个字段值为value;
var json_data = {"my_block":my_block,"my_title":my_title,"descript":descript,"textarea":textarea}; //赋值。sessionStorage相同key自动替换;key不同:添加元素
//这里需要处理异常,sessionStorage最大限额为5M,所以最好做一个判断
try{
sessionStorage.setItem(block_key,JSON.stringify(json_data));
}catch(Exception){
console.log('超出本地存储限额!');
alert("您填写的内容已超过本地存储限额5M");
return false;
} //取值,将sessionStorage数据写入隐藏域数组arr
var storage = window.sessionStorage;
var arr=new Array();
/* 将sessionStorage数据全部写入隐藏域,以数组的形式放在<form>表单里面 */
for(var j=0,len=storage.length;j<len;j++){
var key1 = storage.key(j);
arr.push(sessionStorage.getItem(key1));
}
// console.log(arr); //数组对象
var str_arr = JSON.stringify(arr); //数组转json对象
var str = JSON.stringify(str_arr); //json对象转json字符串
// console.log("json字符串:"+str);
$("input[name='sessionStorage']").attr("value",str_arr);
var v = $("input[name='sessionStorage']").attr("value");
// console.log("sessionStorage隐藏域值:"+v); //json字符串 for(var i=0,len = storage.length;i<len;i++){
var key = storage.key(i);
/*遍历到了点击的click_key,取值*/
if(key == click_key){
/*console.log("章节名相同数据展示");*/
var back_data = JSON.parse(sessionStorage.getItem(click_key));
$("input[name='my_block']").val(back_data.my_block);
$("input[name='my_title']").val(back_data.my_title);
$("textarea[name='descript']").val(back_data.textarea);
$(".editable").html(back_data.descript);
return false;
}
} /*console.log("章节名不同为空");*/
$("input[name='my_block']").val($.trim($(this).find("a").text()));
$("input[name='my_title']").val("");
$("textarea[name='descript']").val("");
$(".editable").html("");
return false;
});
}
} //点击this自定义章节,siblings()上下排序、删除div自动隐藏
function click_custom_hide(){
$("ul#tab li").bind("click",function(){
$(this).find("div").show();
$(this).find("span").show();
$(this).siblings().find("div").hide();
$(this).siblings().find("span").hide();
});
}
jQuery写缓存之:sessionStorage的运用,配合PHP将不同tab页的数据写入后台的更多相关文章
- 为jQuery写插件
很多场合,我们都会调用jQuery的插件去完成某个功能,比如slider. 如下图,做一个div,通过“$( "#slider" ).slider();”的方式直接将div变成sl ...
- 用jquery写循环播放div的相关笔记 珍贵的总结 -1
用jquery写循环播放div line-height应用的元素的 层次? line-heig字ht, 叫行高, 仅仅是指 文/文本, 而不管图片. line-height是容器中 文本行 与 文本行 ...
- 从jQuery的缓存到事件监听
不知道大家有没有发现,用jQuery选择器"选择"之后的DOM上会添加jQuery*********属性. <DIV id=d1 jQuery1294122065250=&q ...
- Jquery IE 缓存问题
jQuery IE缓存问题 解决方法: 1.在AJAX请求的页面后加个随机函数,我们可以使用随机时间函数 在javascript发送的URL后加上t=Math.random() 例如这样:URL+”& ...
- 基于JQUERY写的 LISTBOX 选择器
本文来之于:http://blog.csdn.net/jetsteven/article/details/5104380# 1.经常用到如下图的选择器,而且要支持排序的,所以萌生用JQUERY写一个. ...
- 用jQuery写了一个模态框插件
用jQuery写了一个模态框插件 大家觉得下面的框框好看么, 水印可以去掉(这个任务交给你们了(- o -)~zZ); "info"框 $("div").con ...
- 用jQuery写的最简单的表单验证
近几天完成了关于我们项目的最简单的表单验证,是用jQuery写的,由于之前也一直没学过jQuery,所以自己也是一直处于边摸索边学习的阶段,经过这一段时间的学习,通过查资料啥的,也发现了学习jQuer ...
- 运用jQuery写的验证表单
//运用jQuery写的验证表单 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...
- 用jQuery写的轮播图
效果图: GitHub地址:https://github.com/123456abcdefg/Javascript 大家可以下载源码查看. 与前一篇写的轮播图实现的效果一致,这个是用jQuery写的, ...
随机推荐
- 《学习opencv》笔记——矩阵和图像操作——cvInRange,cvInRangeS,cvInvert and cvMahalonobis
矩阵和图像的操作 (1)cvInRange函数 其结构 void cvInRange(//提取图像中在阈值中间的部分 const CvArr* src,//目标图像 const CvArr* lowe ...
- go语言 defer 高级
go语言defer语句的用法 defer的语法 defer后面必须是函数调用语句,不能是其他语句,否则编译器会出错. package main import "log" func ...
- [runtime] initialize方法讲解
+ (void)initializeDescription(描述) Initializes the class before it receives its first message. 在这个 ...
- 手机网站和PC网站兼容的响应式网页设计
今天跟大家介绍的这个网站叫 媒体查询 官网域名:http://mediaqueri.es/ 该酷站收集了很多响应式设计的案例.全部都是收集的一些励志精美而时尚的网站,使用媒体查询和响应的网页设计. ...
- C++语言笔记系列之十六——赋值兼容规则&多继承的二义性
1.赋值兼容规则 (1)派生类对象能够给基类对象赋值,这样的情况下派生类对象将从基类继承的成员的值赋值给一个基类对象:可是不同意将一个基类的对象赋值给一个派生类. (2)能够将派生类对象的地址赋给基类 ...
- 如何利用启明星Portal门户系统的Page模块构建文档库
利用启明星门户系统的Page模块构架可以搭建企业内部的文档管理系统. (一)应用背景 企业内部通常都会使用共享网盘的方式来存放不同部门之间的文档,例如管理员在服务器上对人事部门增加人事部文档文件夹. ...
- Objective-C:NSValue类的常见用法
特殊类型的包装类:数组.结构体(OC内部的.自定义的).指针 // // main.m // 05-NSValue // // Created by ma c on 15/8/17. // Copyr ...
- OpenCV学习(40) 人脸识别(4)
在人脸识别模式类中,还实现了一种基于LBP直方图的人脸识别方法.LBP图的原理参照:http://www.cnblogs.com/mikewolf2002/p/3438698.html 在 ...
- Vue Cli安装以及使用
因为公司项目要用vue框架,所以会用vue-cli来新建项目.用过vue的都知道,要全局安装vue以及脚手架vue-cli,然后执行vue init webpack projectname来新建v ...
- Retrofit 从入门到了解【总结】
源码:https://github.com/baiqiantao/RetrofitDemo.git 参考:http://www.jianshu.com/p/308f3c54abdd Retrofit入 ...