Day02-ES6

一.proxy代理

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <script>

        let obj = {
            name: "xiaohao",
            age: 18
        }

        let handler = {
            get: function (target, key) {
                console.log(key);

                // console.log("无权访问" + key);

                return target[key];
            },

            set: function (target, key, value) {
                console.log("设置" + key + "成功");
                target[key] = value;
            }
        }

        // 实例化代理
        var proxy = new Proxy(obj, handler);
        console.log(obj);

        console.log(proxy);
        console.log(proxy.name);        // proxy.get

        proxy.gender = "男";            // proxy.set
        console.log(proxy);

    </script>

</body>

</html>

二.reflect反射

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <script>

        let obj = {
            name: "xiaohao",
            age: 18,
            get fun() {
                return this.name;
            }
        }

        // Reflect 反射
        // get 
        console.log(Reflect.get(obj, "name"));

        var newObj = {
            name: "xiaogu",
            age: 20
        }

        console.log(Reflect.get(obj, "fun", newObj));

        Reflect.set(obj, "gender", "男");
        console.log(obj);

    </script>

</body>

</html>

三.组合使用

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <script>

        let obj = {
            name: "xiaohao",
            age: 18
        }

        let handler = {
            get: function (target, key) {
                // ...操作

                return Reflect.get(target, key);
            },
            set: function (target, key, value) {
                return Reflect.set(target, key, value);
            }
        }

        // 实例化代理对象
        let proxy = new Proxy(obj, handler);
        console.log(proxy.name);

        proxy.gender = "男";
        console.log(proxy);

    </script>

</body>

</html>

四.ES6字符串

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <div></div>

    <script>

        let str = "hello";

        // 重复
        console.log(str.repeat(3));

        // 补全
        console.log(str.padStart(10, "o"));

        // 模板字符串
        document.querySelector("div").innerHTML = `<h1>hello</h1>`;

    </script>

</body>

</html>

五.ES6数值

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <script>

        // 十进制
        let num = 10;

        // 二进制
        let num1 = 0b1001;
        console.log(num1);

        // 八进制
        let num2 = 0o1001;
        console.log(num2);

        // 十六进制
        let num3 = 0x1001;
        console.log(num3);

        // 幂运算
        console.log(num ** 3);

        // parseInt()方法补充
        console.log(parseInt("10"));
        console.log(parseInt("10", 8));

        let arr = ["1", "2", "3"];
        console.log(arr.map(parseInt));
        parseInt("1", 0);       // 1
        parseInt("2", 1);       // NaN
        parseInt("3", 2);       // NaN

    </script>

</body>

</html>

六.ES6对象

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <script>

        let name = "zhangsan";
        let age = 18;
        function sayHi() {
            console.log("hello");
        }

        // 对象的简写形式
        var obj = {
            name,
            age,
            sayHi
        }

        let obj2 = {
            gender: "男"
        }

        console.log(obj);
        obj.sayHi();

        // 扩展运算符
        // 扩展运算符(...)用于取出参数对象所有可遍历属性然后拷贝到当前对象。
        let newObj = { ...obj, ...obj2 };        // 浅拷贝
        console.log(newObj);

    </script>

</body>

</html>

七.ES6数组

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <script>

        // Array.of() 创建数组

        console.log(Array.of(1, 2, 3, 4, 5, 6, 7));

        var map = new Map();
        map.set("name", "xiaohao");
        map.set("age", "18");

        console.log(Array.from(map));

        // arr.flat()  抚平数组
        let arr = [1, 2, 3, [4, [5, 6, [7, 8, 9]]]];
        console.log(arr);
        console.log(arr.flat(1));
        console.log(arr.flat(2));
        console.log(arr.flat(3));

        // 扩展运算符
        let arr2 = [1, 2, 3, 4, 5];
        let arr3 = [...arr2];
        console.log(arr3);

    </script>

</body>

</html>

时间戳转成年月日是一个非常常见的需求,在使用 JavaScript 进行开发时也经常会遇到。ES6 中提供的 Date 对象可以非常方便地实现时间戳转成年月日。 在 ES6 中,我们可以使用 Date 类型的 from(timestamp) 方法,将时间戳转换为 Date 类型的对象。基于该 Date 对象,我们可以使用 Date 类型的实例方法,如 getFullYear()、getMonth() 和 getDate(),便捷地获取年份、月份和日期。 下面是一个实现时间戳转成年月日的示例代码: ```javascript const timestamp = 1625681232000; // 时间戳 const date = new Date(timestamp); // 创建 Date 对象 const year = date.getFullYear(); // 获取年份 const month = date.getMonth() + 1; // 获取月份 const day = date.getDate(); // 获取日期 const formattedDate = `${year}-${month}-${day}`; // 格式化日期 console.log(formattedDate); // 输出:2021-7-7 ``` 在上述示例代码中,我们先定义一个时间戳变量,然后使用 new Date(timestamp) 创建了一个 Date 对象。接着,我们分别使用 getFullYear()、getMonth() 和 getDate() 实例方法获取了年份、月份和日期,并将其保存在对应的变量中。最后,我们使用 ES6 中的字符串模板,将年月日格式化成了指定的字符串格式。 通过上述示例,我们可以发现,ES6 中实现时间戳转成年月日非常简单,并且代码可读性也很好。因此,在实际开发中,我们可以大胆使用 ES6 提供的语法糖,提高开发效率和代码质量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值