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页的数据写入后台的更多相关文章

  1. 为jQuery写插件

    很多场合,我们都会调用jQuery的插件去完成某个功能,比如slider. 如下图,做一个div,通过“$( "#slider" ).slider();”的方式直接将div变成sl ...

  2. 用jquery写循环播放div的相关笔记 珍贵的总结 -1

    用jquery写循环播放div line-height应用的元素的 层次? line-heig字ht, 叫行高, 仅仅是指 文/文本, 而不管图片. line-height是容器中 文本行 与 文本行 ...

  3. 从jQuery的缓存到事件监听

    不知道大家有没有发现,用jQuery选择器"选择"之后的DOM上会添加jQuery*********属性. <DIV id=d1 jQuery1294122065250=&q ...

  4. Jquery IE 缓存问题

    jQuery IE缓存问题 解决方法: 1.在AJAX请求的页面后加个随机函数,我们可以使用随机时间函数 在javascript发送的URL后加上t=Math.random() 例如这样:URL+”& ...

  5. 基于JQUERY写的 LISTBOX 选择器

    本文来之于:http://blog.csdn.net/jetsteven/article/details/5104380# 1.经常用到如下图的选择器,而且要支持排序的,所以萌生用JQUERY写一个. ...

  6. 用jQuery写了一个模态框插件

    用jQuery写了一个模态框插件 大家觉得下面的框框好看么, 水印可以去掉(这个任务交给你们了(- o -)~zZ); "info"框 $("div").con ...

  7. 用jQuery写的最简单的表单验证

    近几天完成了关于我们项目的最简单的表单验证,是用jQuery写的,由于之前也一直没学过jQuery,所以自己也是一直处于边摸索边学习的阶段,经过这一段时间的学习,通过查资料啥的,也发现了学习jQuer ...

  8. 运用jQuery写的验证表单

    //运用jQuery写的验证表单 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...

  9. 用jQuery写的轮播图

    效果图: GitHub地址:https://github.com/123456abcdefg/Javascript 大家可以下载源码查看. 与前一篇写的轮播图实现的效果一致,这个是用jQuery写的, ...

随机推荐

  1. 测试 Nginx 作为前端下各种模式的性能

    测试环境: 1:Nginx 独立处理静态面页请求 5000,开了60个线程 2:Nginx作为前端请求转给 Weblogic 12c 处理 (Spring 4.0平台下的动态面页效果如图) 3:Ngi ...

  2. Objective—C中的排序及Compare陷阱

    campare陷阱 NSString有多个compare相关方法: - (NSComparisonResult)compare:(NSString *)string; - (NSComparisonR ...

  3. ActiveMQ使用示例之Queue

    我们使用ActiveMQ为大家实现一种点对点的消息模型. 开发时候,要将apache-activemq-5.12.0-bin.zip解压缩后里面的activemq-all-5.12.0.jar包加入到 ...

  4. Objective-C:OC内部可变对象和不可变对象的深(复制)拷贝问题思考:

    OC内部:可变对象和不可变对象的深(复制)拷贝问题思考:   不可变对象:  例如NSString对象,因为NSString对象是常量字符串,所以,不可以更改其内容,但是可以修改指向该字符串的指针指向 ...

  5. 关于ListView中getView被重复调用的问题

    我用ListView显示数据时,自定义了一个适配器(extends ArrayAdapter),然后重写了getView方法,现在出现一个问题,就是这个getView()方法被重复调用了,比如我的_d ...

  6. activity 保存数据

    activity 保存数据对android的商业项目十分的重要,譬如你在发微博的时候,突然来了一个电话,你洋洋洒洒写了100个字,你不能保存的话,你岂不要卖要骂娘. 那activity究竟是保存数据的 ...

  7. python3 UnicodeEncodeError: 'gbk' codec can't encode character '\xa0' in position 30: illegal multibyte sequence

    昨天用用python3写个日志文件,结果报错UnicodeEncodeError: 'gbk' codec can't encode character '\xa0' in position 30: ...

  8. 职场菜鸟初窥Ant

    对于新入职的新人来说,学校的那一套东西于实际的工作根本不够.诸多的技术知识还得自己去慢慢掌握和理解.对于项目的发布笔者以前也就仅仅使用开发工具集成的发布功能,并未使用过Ant进行项目的发布.因此需要做 ...

  9. HDU 3535 AreYouBusy(混合背包)

    HDU3535 AreYouBusy(混合背包) http://acm.hdu.edu.cn/showproblem.php?pid=3535 题意: 给你n个工作集合,给你T的时间去做它们.给你m和 ...

  10. [Android系列—] 2. Android 项目文件夹结构与用户界面的创建

    前言 在 [Android系列-] 1. Android 开发环境搭建与Hello World 这一篇中介绍了怎样高速搭建Android开发环境, 并成功了建立一个没有不论什么代码更改的 Androi ...