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>
相关推荐
cyforkk28 分钟前
12、Java 基础硬核复习:集合框架(数据容器)的核心逻辑与面试考点
java·开发语言·面试
我材不敲代码5 小时前
Python实现打包贪吃蛇游戏
开发语言·python·游戏
2501_920931705 小时前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
身如柳絮随风扬5 小时前
Java中的CAS机制详解
java·开发语言
0思必得07 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
韩立学长7 小时前
【开题答辩实录分享】以《基于Python的大学超市仓储信息管理系统的设计与实现》为例进行选题答辩实录分享
开发语言·python
东东5167 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
froginwe117 小时前
Scala 循环
开发语言
catino7 小时前
图片、文件的预览
前端·javascript
m0_706653237 小时前
C++编译期数组操作
开发语言·c++·算法