js内置对象:Array对象、Date对象、正则表达式对象、string对象

简介: js内置对象:Array对象、Date对象、正则表达式对象、string对象

Day_04



js内置对象(自定义对象,内置对象,浏览器对象)
利用对象封装自己的数学对象
var myMath={
    PI:3.13141592653589793,
    max:function(){
        var max=arguments[0];
        for(var i=0;i<arguments.length;i++){
            if(arguments[i]>max){
                max=arguments[i];
            }
        }
        return max;
    }
}

Math.floor();向下取整


Math.ceil();向上取整


Math.abs();绝对值


Math.round();四舍五入, .5会往大了取, Math.round(-1.5)>-1 Math.round(1.5)>2


Math.random();会随机取 0=<x<1的数


如果我们想要得到两个数之间的随机数且包含这两个数


Math.floor(Math.random() * (max-min+1))+min


日期对象

获取当前毫秒值

new Date().valuesOf();


new Date().getTime();


+new Date();


Date.now();


秒杀的时间剩余 x天x时x分x秒的计算

得到毫秒值算剩余天剩余时剩余分剩余秒
var d=parseInt(time/60/60/24);//天
var d=parseInt(time/60/60/%24);//时
var d=parseInt(time/60%60);//分
var d=parseInt(time%60);//秒
数组对象
new Array(2);创建一个数组长度为2的,里面2个空元素
new Array(2,3);创建一个数组长度为2,且里面的元素是2和3相当于[2,3]
检测是否为数组
方式一:arr instanceof Array
方式二:Array.isArray(arr);
删除或者添加数组元素的方法
push();在数组的末尾 添加一个或者多个数组元素,push完之后返回新数组的长度.
  eg:var arr=[1,2,3]
     arr.push(4,'pink');
unshift();在我们数组的前面添加一个或者多个数组元素
  eg:arr.unshift('red');
pop();他可以删除数组的最后一个元素,返回的是删除的那个元素.,没有参数
shift(); 在我们数组的前面删除一个数组元素;没有参数,返回的是删除的那个元素.
reverse();方法实现数组的反转.
    arr.sort(function(a,b){
        return a-b;//升序的排列
        return b-a;//降序的排列
    });数组的排序.   
 数组去重的核心为:arr.indexOf(元素);如果该数组中没有此元素则返回-1
     eg: function(arr){
         var newArr=[];
         for(var i=0;i<arr.length;i++){
             if(newArr.indexOf(arr[i])===-1){
                 newArr.push(arr[i]);
             }
         }
         return newArr;
     }
数组转换为字符串:.toString();join();join方法默认按照逗号隔开,可以自行设置以什么符号进行分隔join('-');将以-进行分隔.
var str='1234';
console.log(str.length);
为什么字符串还有length属性呢
因为会把字符串转换为包装类型也就是复杂类型
执行过程如下:
//1:生成临时变量,把简单类型包装为复杂数据类型
var temp=new String('1234');
//2:赋值我们声明的字符变量
str=stemp;
//3:销毁临时变量
temp=null;
目录
相关文章
|
10天前
|
JavaScript 前端开发
如何在 JavaScript 中使用 __proto__ 实现对象的继承?
使用`__proto__`实现对象继承时需要注意原型链的完整性和属性方法的正确继承,避免出现意外的行为和错误。同时,在现代JavaScript中,也可以使用`class`和`extends`关键字来实现更简洁和直观的继承语法,但理解基于`__proto__`的继承方式对于深入理解JavaScript的面向对象编程和原型链机制仍然具有重要意义。
|
13天前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
1月前
|
Java
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性
本文深入探讨了Java中方法参数的传递机制,包括值传递和引用传递的区别,以及String类对象的不可变性。通过详细讲解和示例代码,帮助读者理解参数传递的内部原理,并掌握在实际编程中正确处理参数传递的方法。关键词:Java, 方法参数传递, 值传递, 引用传递, String不可变性。
55 1
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性
|
13天前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。
|
1月前
|
缓存 JavaScript 前端开发
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
31 1
|
1月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
16 2
|
1月前
|
JavaScript 前端开发 大数据
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
15 0
|
1月前
|
JavaScript 前端开发 索引
JavaScript中数组、对象等循环遍历的常用方法介绍(一)
JavaScript中数组、对象等循环遍历的常用方法介绍(一)
21 0
|
1月前
|
人工智能 前端开发 JavaScript
拿下奇怪的前端报错(一):报错信息是一个看不懂的数字数组Buffer(475) [Uint8Array],让AI大模型帮忙解析
本文介绍了前端开发中遇到的奇怪报错问题,特别是当错误信息不明确时的处理方法。作者分享了自己通过还原代码、试错等方式解决问题的经验,并以一个Vue3+TypeScript项目的构建失败为例,详细解析了如何从错误信息中定位问题,最终通过解读错误信息中的ASCII码找到了具体的错误文件。文章强调了基础知识的重要性,并鼓励读者遇到类似问题时不要慌张,耐心分析。
|
1月前
|
存储 Java
Java“(array) <X> Not Initialized” (数组未初始化)错误解决
在Java中,遇到“(array) &lt;X&gt; Not Initialized”(数组未初始化)错误时,表示数组变量已被声明但尚未初始化。解决方法是在使用数组之前,通过指定数组的大小和类型来初始化数组,例如:`int[] arr = new int[5];` 或 `String[] strArr = new String[10];`。