当前位置: 首页 > article >正文

JS进阶 2——构造函数、数据常用函数

JS进阶 2——构造函数、数据常用函数

1.深入对象

  • 创建对象三种方式

    • 通过对象字面量创建:对象名 = { }
    • 通过new Object创建:对象名 = new Object()
    • 使用构造函数实例化多个相似对象:
      • 命名都以大写字母开头
      • 由"new"操作符执行
     function Pig(name, age, gender) {
          this.name = name
          this.age = age
          this.gender = gender
        }
        //创建小小怪对象
        const Xxg = new Pig('小小怪', '18', '女')
        //创建大大怪对象
        const Ddg = new Pig('大大怪', '20', '男')  
    

2.内置构造函数

  • 基本包装类型:为什么基本数据类型例如string类型有length属性,因为JS底层将简单数据类型包装成了引用数据类型。

  • Object:常用的三个静态方法(只有构造函数Object可以调用)

    • object.keys(对象名):获取对象所有的键(属性名)
    • object.values(对象名):获取对象所有属性值
    • object.assgin( , )
     const o = { name: '小小', age: '18' }
       //1.获取所有属性名
     const re = Object.keys(o)
     console.log(re) //['name','age']
       //2.获取所有属性值
     console.log(Object.values(o)) //['小小','18']
       //3.拷贝对象 
     const oo = {}
     Object.assign(oo, o)
     console.log(oo)
        //拷贝应用  给对象添加属性
     Object.assign(o, { gender: '女' })
     console.log(o)
    
  • Array

    • 常用实例方法(去mdn查看具体用法)
    方法作用说明
    forEach遍历数组不返回数组,用于查找遍历数组元素
    filter过滤数组返回新数组,返回的是满足条件的数组元素
    map迭代数组返回新数组,返回的是处理之后的数组元素
    reduce累计器返回累计处理的结果,经常用于求和
    join数组转字符串返回字符串,返回的是数组元素以特定方式拼接而成的字符串
    find查找元素返回符合测试条件的第一个数组元素
    every检测元素是否都符合指定条件若都符合返回true,反之返回false
    some检测是否铀元素满足指定条件若有元素满足条件返回true,反之返回false
    concat合并数组返回新数组
    sort对原数组单元值排序
    splice替换数组单元
    reverse反转数组
    findIndex查找元素的索引值
    • reduce基本语法:
     arr.reduce(function () { }, 起始值)
     arr.reduce(function (上一次值, 当前值) { }, 初始值)
    
     const arr = [1, 5, 8]
        //1.没有初始值
        const total = arr.reduce(function (prev, current) {
          return prev + current
        })
        console.log(total) //14
        //2.有初始值
        const total1 = arr.reduce(function (prev, current) {
          return prev + current
        }, 10)
        console.log(total1) //24
    
    • 常用静态方法:Array.from():伪数组转换为真数组(伪数组没有数组的pop,push等方法)
     <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
      </ul>
      <script>
        const lis = document.querySelectorAll('ul li')
        const liss = Array.from(lis)
        liss.pop()
        console.log(liss);
      </script>
    
  • String

    • 实例属性或方法
    实例属性或方法说明
    length获取字符串长度
    split(‘分隔符’)用来将字符串拆分为数组
    substring(截取第一个字符串的索引,结束的索引号)用于字符串截取
    startsWith(检测字符串,检测位置索引号)检测是否以某字符开头
    includes(检测的字符串,检测位置索引号)判断字符串是否包含在另一个字符串中
    toUpperCase将字母换成大写
    toLowerCase将字母换成小写
    indexOf检测是否包含某字符
    endsWith检测是否以某字符结尾
    replace用于替换字符,支持正则匹配
    match用于查找字符,支持正则匹配
 // 1.字符串转为数组
    const str = 'pink,red'
    const arr = str.split(',')
    console.log(arr)
    // 2.字符串截取
    const str1 = '我今天很开心'
    console.log(str1.substring(4, 6)); //开心
    //3.startWith:检测字符串开头
    const str2 = '今天是星期'
    console.log(str2.startsWith('星期', 3)) //true
    //4.includes :检测字符串是否包含
    const str3 = '大大怪将军,我是小小怪,你在哪里呀'
    console.log(str3.includes('小小怪'))
  • Number

    • toFixed保留小数位的长度
    const price =23.128789
    console.log(price.toFixed(2)) //23.13
    

http://www.kler.cn/a/329887.html

相关文章:

  • 菜品管理(day03)
  • Google常用语法解析
  • Go语言中http.Transport的Keep-Alive配置与性能优化方法
  • java根据模板导出word,并在word中插入echarts相关统计图片以及表格
  • 编译pytorch——cuda-toolkit-nvcc
  • RabbitMQ(三)
  • 【Java】—— 集合框架:Collection接口中的方法与迭代器(Iterator)
  • 基于Springboot的在线订餐系统设计与实现(论文+源码)_kaic
  • STM32使用Keil5 在运行过程中不复位进入调试模式
  • Html5知识点介绍
  • SpringCloud-基于Docker和Docker-Compose的项目部署
  • python UNIT3 选择与循环(1)
  • 使用微服务Spring Cloud集成Kafka实现异步通信
  • 【Java基础】Java面试基础知识QA(上)
  • 关于主流电商API接口的测试及返回【douyin电商SKU接口】
  • 螺狮壳里做道场:老破机搭建的私人数据中心---Centos下Docker学习01(环境准备)
  • 基于深度学习的图像去噪与去模糊
  • ACL(Access Control List)访问控制列表
  • 彩虹易支付最新版源码及安装教程(修复BUG+新增加订单投诉功能)
  • 推送k8s镜像到阿里云服务器
  • 滚雪球学Oracle[2.5讲]:数据库初始化配置
  • 开发指南063-上传文件到百度网盘
  • MindSearch 部署到Github Codespace 和 Hugging Face Space
  • VUE3.5版本解读
  • 5G NR 协议规范表(对应3GPP 协议编号)
  • django的模型层介绍与配置