zoukankan      html  css  js  c++  java
  • map字典,储存cookie,切换账户,展示购物车不同商品

    1:首页

    • 1,静态html5+css做好基本样式

    html5,css,jQery, sass

    • 2,jsonp的方式src引入模拟的json数据//这里用的jsonp方式拿数据,详情有使用ajax

    遍历json数据:

    
    let data = like['msg']; //获取json数据列表
    let like_lists = document.querySelector('.like_lists'); //获取ul便签
    
    
    //通过循环遍历出后台收据,每循环一次就通过js的dom生成节点,依次插入标签中。并附上类名与id。
    
    

    2:跳转详情 ajax异步请求

    • 关键:indexOf,continue ajax
    
    //首页给a标签绑定一个宝贝的唯一id,点击跳转详情页,通过herf发送这条数据
    a1.href = `./front/pages/detail_page.html?id=${itemId}`;
    
    //详情接受地址数据
    function getUrlParam(name) {
                var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //构造一个含有目标参数的正则表达式对象
                var r = window.location.search.substr(1).match(reg); //匹配目标参数
                if (r != null) return unescape(r[2]);
                return null; //返回参数值
    }
    //ajax请求json数据,indexOf判断列表是否包含次数据。
    for (let i = 0; i < data.msg.length; i++) {
        // let data = xq['msg'][i]['itemId'];
        if (data.msg[i]['itemId'].indexOf(id) === -1) { /不包含id
            continue; //跳出  //多个
            //如果不包含就跳出,不打印。*注意要添加循环列表的索引值i
        }
    }
    
    

    3:详情页遍历

    • 使用到 jQuery sass gulp

    主图部分,小盒子里的图片,通过循环给每个img的src更换图片。当鼠标移入小盒子里时,大盒子和放大镜里img的src更换成小盒子里的src。

    
    for (let i = 0; i < imgBtn.length; i++) {
        imgBtn[i].onmouseover = function() {
            oBig.children[0].src = imgBtn[i].childr.src;
            oSmall.children[0].src = imgBtn[i].chi[0].src;
        }
    }
    
    
    let imgBtn = document.querySelectorAll('.samll_box'); //5个小盒子
    let oSmall = document.getElementById('oSmall'); //盒子  里面有img
    let oBig = document.getElementById('oBig');
    oSmall.children[0].src = imgBtn[0].children[0].src;//默认5小盒子里的第一个展示在大盒子上
    
    

    4:登录 注册 页面 模块化

    • 使用到 PHP mysql jQuery sass gulp ajax localStorage

    注册:

    • 使用到jQuery插件,方便获取标签,而且它的选择器很方便。
    • 当鼠标获取input焦点时触发focus事件,提示按正则要求输入
    • 鼠标离开时触发blur事件,判断inpu的val()是否为空,是否满足正则条件,如果条件符合正则要求切不为空则提示,该用户名可注册
    • 点击注册时,ajax提交后台,如果该用户名已别注册则返回一个提示"该用户名已被注册"
    • 注册完成后,使用setTimeout()延迟3s打开登录界面

    登录:

    • 使用到jQuery插件,方便获取标签,而且它的选择器很方便。
    • 构造函数,通过prototype继承方法 ,触发登录事件时,执行函数。判断用户名与密码是否正确
    • 登录成功,将用户名保存本地,并跳转首页
    
     localStorage.setItem("username", $('#username').val());
    
    • 首页跳转加载时onload触发下面的函数获取登录成功时保存本地的用户名,并展示
    
     load_data() {
            var theme = localStorage.getItem("username");
            if (theme == null || theme == "") {
                $('.login_show').hide();
                $('.unlogin').show();
    
            } else {
                $('.login_show').show().children('.login_name').text(theme).css('color', 'red')
                $('.unlogin').hide();
            }
    
        }
    
    • 点击退出时,触发函数,清除本地用户名和load_data()函数,刷新局部
    
    exitu() {
            localStorage.removeItem("username");
            //刷新部分
            this.load_data();
         }
    

    5:添加购物车思路

    • 使用到 jQuery sass gulp ajax cookie

    • 点击详情页 购物车 触发事件。执行函数,将次宝贝id存入cookie保存,并提示添加购物车完成

    • 当用户点击 进入购物车 按钮。触发事件,执行函数,将cookie的value值遍历出来,同ajax异步请求json文件,indexOf判断筛选。将包含的商品价格 图片 展示与页面。

    • 编写计算器。进行数量 ,价格计算.

    注意点:
    最后会与结算的计算器调用的函数必须要在ajax里面写或者调用,不然获取不了那些生成的元素,从而得不到里面的数据!


    购物车进阶版本

    • 上面思路,触发加入购物车事件后,商品直接存入cookie,没有与用户名绑定,用户体验度极差。以下是用户与商品id绑定思路!

    字典对象方法

    var dic={
        admin:[1,2,3],
        nihaoya:[4,5,6]
    }
    
    // 1、获取本地json串 -- String str = Local.getItem("one");"{admin:["1","2","3"],  admin1:[shopcar],admin2:[]}"
    // 2、把json串转换成字典 -- Map dic = JSONObject.parse(str);  {admin:["1","2","3"],admin1:[shopcar],admin2:[]}
    // 3、获取自己的购物车数据 -- List shopCar = dic[admin];       ["1","2","3"]
    // 4、把需要添加到购物车的商品赋值给shopCar -- shopCar.add(data);["1","2","3","4"]
    // 5、把dic转换成json -- String json = JSONObject.toJSONString(dic); {admin:["1","2","3"],admin1:[shopcar],admin2:[]}"
    // 6、保存json到本地  -- Local.saveItem("one",dic);
    
    var locaname = localStorage.getItem('username');
    var li = []; //购物车
    var dictionary = {}; //创建一个空对象
    if (!getCookie(0)) {
        // li = dictionary[locaname];
        if (dictionary[locaname] === undefined) {
            dictionary[locaname] = li;
    
    } else {
        var dic = JSON.parse(getCookie(0));cookie 并解析
        // li = dic[locaname]; //将对应字典里key的v值给自己的购物车
        if (dic[locaname] !== undefined) {
            li = dic[locaname];
        }
    }
    
    if (!getCookie(0)) {
    
        li.push(data.msg[i]['itemId']);
        dictionary[locaname] = li;
        var dobj = JSON.stringify(dictio
    
    } else {
    
        li.push(data.msg[i]['itemId']);
        dic[locaname] = li;
        var dobj = JSON.stringify(dic);
    
    }
    
    // li.push(data.msg[i]['itemId']);
    // setCookie(i, data.msg[i]['itemId'
    setCookie(0, dobj, 7);
    
    • 注意点:函数执行开始时,判断cookie是否有上一次存储的值,如果有,就赋值给dic,如果没有就得声明一个空对象,然后将list赋值给它!触发事件时也需要判断。存储json,读取时相同名。

    
      $.ajax({
                    //请求方式为get
                    type: "GET",
                    //json文件位置
                    url: "../../data/xqq.json",
                    //返回数据格式为json
                    dataType: "json",
                    //请求成功完成后要执行的方法
    
                    success: function (data) {
    
                        // console.log(dictionary[locaname]);
                        // 1、获取本地数据dictionary {name1:[shopcar],name2:[]}
                        // 2、获取自己的购物车数据 dictionary[locaname]
                        // 3、赋值给一个list var li=dictionary[locaname]
                        // 4、list插入需要加入到购物车的数据 li。add(data)
                        // 5、把list赋值给自己的购物车数据 dictionary[locaname]=li
                        // 6、保存dictionary local。save      
    
                        // 1、获取本地json串 -- String str = Local.getItem("one");             "{admin:["1","2","3"],admin1:[shopcar],admin2:[]}"
                        // 2、把json串转换成字典 -- Map dic = JSONObject.parse(str);            {admin:["1","2","3"],admin1:[shopcar],admin2:[]}
                        // 3、获取自己的购物车数据 -- List shopCar = dic[admin];                 ["1","2","3"]
                        // 4、把需要添加到购物车的商品赋值给shopCar -- shopCar.add(data);          ["1","2","3","4"]
                        // 5、把dic转换成json -- String json = JSONObject.toJSONString(dic);    "{admin:["1","2","3"],admin1:[shopcar],admin2:[]}"
                        // 6、保存json到本地  -- Local.saveItem("one",dic);
    
                        var locaname = localStorage.getItem('username');
                        var li = []; //购物车
                        var dictionary = {}; //创建一个空对象 存数据
    
                        if (!getCookie(0)) {
                            // li = dictionary[locaname];
                            if (dictionary[locaname] === undefined) {
                                dictionary[locaname] = li;
                            }
    
                        } else {
                            var dic = JSON.parse(getCookie(0)); //获取cookie 并解析
                            // li = dic[locaname]; //将对应字典里key的value赋值给自己的购物车
                            if (dic[locaname] !== undefined) {
                                li = dic[locaname];
                            }
                        }
    
    
                        for (let i = 0; i < data.msg.length; i++) {
                            // let data = xq['msg'][i]['itemId'];
    
                            if (data.msg[i]['itemId'].indexOf(id) === -1) { //data不包含id
                                continue; //跳出  //多个
                                //如果不包含就跳出,不打印。*注意要添加循环列表的索引值i
                            }
                            // 遍历详情页
                            // console.log(data.msg[i]['goods_gallery_urls'][2]);
                            for (let a = 0; a < 5; a++) {
                                let img1 = document.createElement('img');
                                img1.className = 'img11';
                                img1.src = data.msg[i]['goods_gallery_urls'][a]
                                imgBox[a].appendChild(img1)
                            }
                            // 标题
                            let productMainName = document.getElementById('productMainName');
                            productMainName.innerHTML = data.msg[i]['goods_name'];
                            // 提示
                            let buy21 = document.getElementById('buy21');
                            buy21.innerHTML = data.msg[i]['goods_desc'];
    
                            let goods_eval_score = document.getElementById('goods_eval_score');
                            goods_eval_score.innerHTML = data.msg[i]['payPoint'];
    
                            let category_id = document.getElementById('category_id');
                            category_id.innerHTML = data.msg[i]['srcPoint']
    
                            // 店名
                            $('.store_name').text(data.msg[i]['mall_name']);
    
                            // 点击触发事件存储本地
                            $('.store_car').click(() => {
    
                                if (!getCookie(0)) {
    
                                    li.push(data.msg[i]['itemId']);
                                    dictionary[locaname] = li;
                                    var dobj = JSON.stringify(dictionary);
    
                                } else {
                                    li.push(data.msg[i]['itemId']);
                                    dic[locaname] = li;
                                    var dobj = JSON.stringify(dic);
    
                                }
    
                                // li.push(data.msg[i]['itemId']);
                                // setCookie(i, data.msg[i]['itemId'], 7);
    
                                setCookie(0, dobj, 7);
    
                                alert('加入购物车成功,付款请进入购物车')
    
                            })
    
                        }
    
    
                        // dictionary[locaname] = [dakhadsdhksa, adajksjlkads, 3]
    
                        // var a = ['sas', 'sa']
                        // a.push('assa')
                        // dictionary[locaname] = a;
    
    
                        // var keys = [];
                        // dictionary.locaname = [12, 32, 54]
                        // for (var key in dictionary) {
                        //     keys.push(key);
                        // }
                        // dictionary["locaname"].push(77);
    
                        // console.log(dictionary);
    
                        // 详情主图
                        let imgBtn = document.querySelectorAll('.samll_box'); //5个小盒子
                        let oSmall = document.getElementById('oSmall'); //获取盒子  里面有img
                        let oBig = document.getElementById('oBig');
    
                        oSmall.children[0].src = imgBtn[0].children[0].src; //默认5小盒子里的第一个展示在大盒子上
    
                        for (let i = 0; i < imgBtn.length; i++) {
                            imgBtn[i].onmouseover = function () {
                                oBig.children[0].src = imgBtn[i].children[0].src;
                                oSmall.children[0].src = imgBtn[i].children[0].src;
                            }
                        }
    
    
                    }
                });
            });
    
    //购物车js
    
     $.ajax({
            type: "GET",
            // url: "../../data/like_like.json",
            url: "../../data/like_like.json",
            data: "data",
            dataType: "json",
            success: function(response) {
                let username = localStorage.getItem('username'); //本地名
    
    
                let dic = JSON.parse(getCookie(0)); //json对象
                console.log(dic);
    
                var keys = []; //遍历dic长度
    
                for (var key in dic) {
                    keys.push(key);
                }
    
    
                if (keys.indexOf(username) == -1) {
                    $('.rember').show();
                    $('.pay').hide();
    
                } else {
                    $('.pay').show();
    
                    let lkel = response.msg.length;
    
                    // strc.length 
                    // dic[username].length //当前用户名里面的value值
    
                    for (let a = 0; a < dic[username].length; a++) { //循环遍历value值
    
                        // var arr = strc[a].split('=')[1] //arr=cookie的
                        var arr = dic[username][a];
    
                        for (let i = 0; i < lkel; i++) { //循环遍历json文件 
                            if (response.msg[i]['itemId'].indexOf(arr) === -1) { //json文件里是否包含dic[username]里面的value
                                continue;
                            }
                            // console.log(response.msg[i]['nick']);
                            // console.log(response.msg[i]['icon']);
    
                            let li1 = document.createElement('li');
                            li1.className = 'carlis';
                            $('.shop_lis').append(li1);
                            let img1 = document.createElement('img');
                            img1.src = response.msg[i]['icon'];
                            img1.className = 'goods_img';
    
                            li1.append(img1);
    
                            let p1 = document.createElement('p');
                            p1.innerHTML = response.msg[i]['title'];
                            li1.append(p1);
                            // var p1 = $("<p></p>").text(response.msg[i]['title']);
    
                            let div1 = document.createElement('div');
                            div1.className = 'goods_bottom';
                            div1.innerHTML = '¥';
                            li1.append(div1);
    
                            let span1 = document.createElement('span');
                            span1.className = 'goods_price';
                            span1.innerHTML = response.msg[i]['srcPoint'];
    
                            div1.append(span1)
    
                            let div_num = document.createElement('div');
                            div_num.className = 'num';
                            div1.append(div_num);
    
                            let div_minus = document.createElement('div');
                            let div_plus = document.createElement('div');
                            let span2 = document.createElement('span');
                            div_minus.innerHTML = '-';
                            div_plus.innerHTML = '+';
                            span2.innerHTML = '0';
                            div_minus.className = 'minus';
                            div_plus.className = 'plus';
    
    
                            div_num.append(div_minus);
                            div_num.append(span2);
                            div_num.append(div_plus);
    
                        }
    
                    }
                }
    
                $(".plus").click(function() {
                    var num = $(this).parent().children("span");
                    //单品数量增加
    
                    num.text(parseInt(num.text()) + 1);
                    //商品总数增加
                    var totalNum = parseInt($(".totalNum").text());
                    totalNum++
                    $(".totalNum").text(totalNum);
                    //计算总价
                    var goods_price = parseFloat($(this).parent().parent().children(".goods_price").text());
                    $(".totalPrice").text(parseFloat($(".totalPrice").text()) + goods_price);
                });
    
                //点击减少按钮触发事件
                $(".minus").click(function() {
                    var num = $(this).parent().children("span");
                    if (parseInt(num.text())) {
                        num.text(parseInt(num.text()) - 1);
                        var totalNum = parseInt($(".totalNum").text());
                        totalNum--
                        $(".totalNum").text(totalNum);
                        var goods_price = parseFloat($(this).parent().parent().children(".goods_price").text());
                        $(".totalPrice").text(parseFloat($(".totalPrice").text()) - goods_price);
                    } else {
                        num.text("0");
                    }
    
                    // console.log(parseInt(num.text()));
    
    
                });
    
                //点击付款
                $('#pay_money').click(() => {
                    console.log($('.totalPrice').text());
    
                    if ($('.totalPrice').text() === '00') {
                        alert('请输入商品数量');
                    } else {
                        $('.pay_photo').show(1000);
    
                    }
    
                })
                $('#pay_close').click(() => {
                    $('.pay_photo').hide();
                })
    
            }
        });
    
  • 相关阅读:
    [转][Silverlight] aspx页面上传递参数给Silverlight插件的方法
    [C#] 利用cmd远程网内机器,实现文件互传
    [CSS] 对于一个连在一起很长的字符串,在页面上控制换行
    [CSS] 设置input和img在同一行上
    [MySQL] 记MySQL与MS SQL的几点不同
    [JQuery] 利用jquery的ajax调用后台的WebService公共方法和网页的静态方法
    【计算机组成原理】——计算机发展简史
    【计算机组成原理】——计算机的分类
    【JavaScript高级程序设计4th】第1章 什么是JavaScript——总结
    css重置样式表(两种版本)
  • 原文地址:https://www.cnblogs.com/wangqingjiu/p/11104544.html
Copyright © 2011-2022 走看看