localStorage本地存储——记住用户名和密码

localStorage本地存储——记住用户名和密码

html进行布局:主要就是需要有一个文本框和一个密码框,以及需要一个记住密码的复选框

 <section>
        <div>
            <label for="username">用户名:</label><input type="text" id='username' name='username'>
        </div>
        <div>
            <label for="password">&nbsp;&nbsp;&nbsp;码:</label><input type="password" id='password' name='password'>
        </div>
        <div>
            <input type="checkbox" class='rember' id="rember" style="margin-right: 10px;"><label
                for="rember">记住密码</label>
        </div>
    </section>

css布局

 <style>
        * {
            box-sizing: border-box;
        }

        body {
            background-color: #ccc;


        }

        section {
            padding-top: 100px;
            width: 500px;
            height: 500px;
            background-color: #fff;
            margin: auto;
            margin-top: 100px;
        }

        div {
            text-align: center;
        }

        input {

            margin: 10px auto;
        }
    </style>

JavaScript思路:

  1. 当然是获取元素啦,这里需要操作哪些元素呢?用户名的文本框,密码的密码框,记住密码的复选框
  2. 通过本地存储的localStorage中的getItem方法获取存储的账户信息,如果存在就将获取到的用户名和密码作为内容给文本框和密码框的值,同时需要让复选框处于勾选状态
  3. 通过对复选框做change事件监听(使用点击事件也是可以的),只需要判断复选框是否被勾选上,如果勾选了,就需要将文本框的信息存储到本地,如果取消勾选就是不需要记住密码,就会从本地存储中删除
 <script>
        var username = document.querySelector('#username');
        var password = document.querySelector("#password");
        var rember = document.querySelector('.rember')
        var account = JSON.parse(localStorage.getItem('account'));
         //有账号的信息
        if (account) {
            //从获取到的账号信息中,把用户名和密码分别赋值给文本框和密码框,并且需要让复选框处于勾选状态
            username.value = account.username;
            password.value = account.password;
            rember.checked = true;
        }
        //记住密码复选框的change事件
        rember.onchange = function () {
            //判断复选框是否被勾选上
            if (this.checked) {
                //如果是勾选状态,就将文本框的值和密码框的值存储到本地存储
                var data = { username: username.value, password: password.value }
                localStorage.setItem('account',JSON.stringify(data));
            }else{
                //如果没有勾选,就将本地存储删掉
                localStorage.removeItem('account')
            }
        }



    </script>

结果展示:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值