79-82 call和apply,arguments,Date对象,Math

call和apply

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

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

<body>
    <script>

        function fun(a,b) {
            //alert(this);
            console.log("a="+a);
            console.log("b="+b);
        }
        //call()和apply()
        //这两个方法都是函数对象的方法,需要通过函数对象来调用
        //当对函数调用call()和apply()都会调用函数执行
        //在调用call()和apply()可以将一个对象指定为第一个参数
        //此时这个对象将会成为函数执行时的 this
        //call () 方法可以将实参在对象之后依次传递
        //apply () 方法需要将实参封装到一个数组中统一传递
        //this 的情况:
        // 1. 以函数形式调用时,this 永远都是 window
        // 2. 以方法的形式调用时,this 是调用方法的对象
        // 3. 以构造函数的形式调用时,this 是新创建的那个对象
        // 4. 使用 call 和 apply 调用时,this 是指定的那个对象

        var obj = {
            name: "obj",
            sayName:function() {
                alert(this.name);
            }
        };
        var obj2 = {
            name: "obj2"
        };
       // obj.sayName.apply(obj2);
        fun.call(obj,1,2);

    </script>
</body>

</html>

arguments

在调用函数时,浏览器每次都会传递进两个隐含的参数

函数的上下文对象

封装实参的对象arguments

arguments是一个类数组对象(不是数组),它可以通过索引来操作数据,也可以获取长度

在调用函数时,我们所传递的实参都会在argument中保存

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

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

<body>
    <script>
       //arguments.length可以用来获取实参的长度
       //我们即使不定义形参,也可以通过argunments来使用实参,只不过比较麻烦
       //arguments[0]表示第一个参数
       //arguments[1]表示第二个参数
       //它里边有一个属性叫做callee,这个属性对应一个函数对象,就是当前正在指向的函数的对象

        function fun(a,b) {
            console.log(arguments[1]);
            console.log(arguments.callee==fun);
            console.log(arguments instanceof Array);
            console.log(arguments.length);
            console.log(Array.isArray(arguments));
        }
        fun("hello",true);
        
       
    </script>
</body>

</html>

Math

  • Math和其他的对象不同,它不是一个构造函数;它属于一个工具类,不用创建对象,它里边封装了数学运算相关的属性和方法
html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

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

<body>
    <script>

        //Math
        console.log(Math.PI);
        //abs()
        console.log(Math.abs(-10));
        //ceil  对一个数向上取整
        console.log(Math.ceil(5.3));
        //floor  对一个数向下取整
        console.log(Math.floor(5.8));
        
    </script>
</body>

</html>

Date对象

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

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

<body>
    <script>

        //Date对象
        //在JS中使用Date对象来表示一个时间

        //创建一个Date对象
        //如果直接使用构造函数创建一个Date对象,则会封装为当前代码执行的时间
        var d=new Date();
        console.log(d);

        //创建一个指定的时间,需要在构造函数中传递一个表示时间的字符串作为参数
        //格式:月份/日/年份 时:分:秒
        var d2=new Date("11/29/25 20:01:50");
         console.log(d2);

         //获取日期时几日
         var date=d2.getDate();
         var day=d2.getDay();
        console.log("date="+date);

        //一周中的某一天
        console.log("day="+day);
    </script>
</body>

</html>
相关推荐
一 乐1 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
Boilermaker19921 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
MM_MS1 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测
C_心欲无痕1 小时前
ts - tsconfig.json配置讲解
linux·前端·ubuntu·typescript·json
清沫1 小时前
Claude Skills:Agent 能力扩展的新范式
前端·ai编程
꧁Q༒ོγ꧂2 小时前
LaTeX 语法入门指南
开发语言·latex
njsgcs2 小时前
ue python二次开发启动教程+ 导入fbx到指定文件夹
开发语言·python·unreal engine·ue
alonewolf_992 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
yinuo2 小时前
前端跨页面通信终极指南:方案拆解、对比分析
前端
古城小栈2 小时前
Rust 迭代器产出的引用层数——分水岭
开发语言·rust