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. JSON.parse()和jQuery.parseJSON()的区别

    jQuery.parseJSON(jsonString) : 将格式完好的JSON字符串转为与之对应的JavaScript对象   (jquery 方法) 1 2 3 var str = '[{&qu ...

  2. style="visibility: hidden"和 style=“display:none”之间的区别

    style=“display:none” 隐藏页面元素: <html> <head> <script type="text/javascript"&g ...

  3. 字符测试篇isalnum isalpha isascii iscntrl isdigit isgraphis islower isprint isspace ispunct isupper isxdigit

    isalnum(测试字符是否为英文或数字) 相关函数 isalpha,isdigit,islower,isupper 表头文件 #include<ctype.h> 定义函数 int isa ...

  4. 数据库实例: STOREBOOK > 表空间 > 编辑 表空间: UNDOTBS1

    ylbtech-Oracle:数据库实例: STOREBOOK  >  表空间  >  编辑 表空间: UNDOTBS1 表空间  >  编辑 表空间: UNDOTBS1 1. 一般 ...

  5. Objective-C:分类(Category、extension)

    分类(Category .Extension) (一)分类的划分     (2) 1.(命名的类别)类别Category:只能添加新的方法,不能添加新变量.           2.(未命名的类别)类 ...

  6. java 中的resultset的类型

    结果集(ResultSet)是数据中查询结果返回的一种对象,可以说结果集是一个存储查询结果的对象,但是结果集并不仅仅具有存储的功能,他同时还具有操纵数据的功能,可能完成对数据的更新等. 结果集读取数据 ...

  7. Android硬件入门-照相机

    学习Android不能不学习照相机,现在各种美容相机,微信朋友圈发图,现在升级之后直接下拉就可以照相了,各种艳照的的源头也是照相机,扯远了,有点邪恶了,还是简单学习一下Android中照相机的使用,A ...

  8. 4 Sum leetcode java

    题目: Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = ...

  9. tp 生成静态页

    $this->fetch()返回的是html 可以直接写入到HTML文件内生成静态页

  10. 转: telnet命令学习

    1.每天一个linux命令(58):telnet命令 转自: http://www.cnblogs.com/peida/archive/2013/03/13/2956992.html telnet命令 ...