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();
    });
}

 

posted @ 2017-05-12 13:00  PHP急先锋  阅读(3726)  评论(0编辑  收藏  举报