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. 【微信小程序】处理时间格式,时间戳转化展示时间格式问题,调用外部js的默认方法function的问题

    默认的 小程序中new Date()显示的时间是这样的: 格式化时间的显示怎么做: 小程序的根目录下util目录下默认有一个util.js文件 其中util.js文件内容是: //数据转化 funct ...

  2. bt z

    比特币从2008年开始启动,到09年创始区块的出现,甚至一直到10年和11年都只是中本聪自己一个人在运行这套程序.在早期这个极少数人参与到游戏里,大家运行一个软件,这个软件既是钱包也是挖矿软件,进行P ...

  3. JQuery文件上传及以Base64字符串形式呈现图片

    一:上传之 首先,你必然得有一个 file input,如下: <td>     <img id="imgGif" style="display: no ...

  4. [转]C++之运算符重载(2)

    上一节主要讲解了C++里运算符重载函数,在看了单目运算符(++)重载的示例后,也许有些朋友会问这样的问题.++自增运算符在C或C++中既可以放在操作数之前,也可以放在操作数之后,但是前置和后置的作用又 ...

  5. 数学图形之罗马曲面(RomanSurface)

    罗马曲面,像是一个被捏扁的正四面体. 本文将展示罗马曲面的生成算法和切图,使用自己定义语法的脚本代码生成数学图形.相关软件参见:数学图形可视化工具,该软件免费开源.QQ交流群: 367752815 维 ...

  6. [10] 圆管(Pipe)图形的生成算法

    顶点数据的生成 bool YfBuildPipeVertices ( Yreal radius, Yreal assistRadius, Yreal height, Yuint slices, YeO ...

  7. DIV焦点事件详解 --【focus和tabIndex】​

    添加 tabindex='-1' 属性: 默认:获取不到焦点事件(blur) 1 <div class="wl-product" id="wl-product&qu ...

  8. c++call back

    #include "stdafx.h" struct A; typedef void(A::*MemFuncPtr) (int* e); class A { int a; }; c ...

  9. M2Mqtt is a MQTT client available for all .Net platform

    Introduction M2Mqtt is a MQTT client available for all .Net platform (.Net Framework, .Net Compact F ...

  10. [Backbone]1. Module, View classed

    Welcome to the Anatomy of Backbone.js challenges! We're going to be building a simple Appointment ap ...