仿天猫网站开发3:模态登陆窗口

项目位置仿天猫网站

需要实现的功能

这里写图片描述
点击“立即购买”或“加入购物车”时,判断当前是否为登录状态,如果未登录,则弹出模态窗口。


实现方式

首先是如何判断当前是否为登陆状态?查阅资料可知:
资料查的乱套了,就先省略吧
这里我想到的是,通过在模板中创建一个js变量,通过模板逻辑判断当前是否为登陆状态,然后改变这个变量的值为ture或者false,模板中代码片段如下:

<script>
    var MyViewVar = {
        stock: {{ item.stock }},
        {% if request.user.is_authenticated %}
            is_login:true,
        {% else %}
            is_login:false,
        {% endif %}
    };
</script>

然后在js文件中根据这个is_login标记判断是否为登陆状态,代码如下:

    //监听购买按钮
    $(".buyLink").click(function () {
        if (MyViewVar.is_login) {
            var num = $(".productNumberSetting").val();
            location.href = $(".buyLink").attr("href") + "&num=" + num;
        } else {
            $("#loginModal").modal('show');
        }
    });

经过测试发现,在未登录情况下确实可以弹出模态登陆页面,但紧接着会刷新页面。为了页面不刷新,需要使用Ajax


使用Ajax异步获取数据

将模板文件中的部分修改为:

<script>
    var MyViewVar = {
        stock: {{ item.stock }},
        {% if request.user.is_authenticated %}
            is_login:true,
        {% else %}
            is_login:false,
        {% endif %}
        page:"{% url 'product:item' item.id %}",
    };
</script>

其中page就是请求的页面url,然后将js文件中对应方法改为:

    $(".buyLink").click(function(){
        var page = MyViewVar.page;
        $.get(
                page,
                function(){
                    if (MyViewVar.is_login) {
                        var num = $(".productNumberSetting").val();
                        location.href = $(".buyLink").attr("href") + "&num=" + num;
                    } else {
                        $("#loginModal").modal('show');
                    }
                }
        );
        return false;
    });

经过测试确实成功开启了模态窗口。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值