JavaScript高级 —— 学习(二)

目录

一、深入对象

(一)创建对象三种方式

1.利用对象字面量创建

2.利用 new Object() 创建

3.利用构造函数创建

(二)利用构造函数创建对象

1.构造函数介绍

2.约定

3.实例化执行过程

(三)实例成员 & 静态成员

1.实例成员

说明:

2.静态成员

说明:

(四)内置构造函数

1.包装类型:

String:

length:

split(): 拆分成数组

substring(): 截取

 startsWith():是否以...开始

includes(): 是否拥有...

 Number:

toFixed(): 小数位

2.引用类型:

Object:

常用的静态方法:

拷贝操作

Array:

遍历数组 forEach

过滤数组 filter

迭代数组 map

累计器 reduce

伪数组转化成真数组

其他方法:

练习:利用构造函数创建多个对象

练习:数组合并小案例

 练习:字符串数组相互转换练习

综合练习:购物车


一、深入对象

(一)创建对象三种方式

1.利用对象字面量创建
<body><script>const obj = {}</script>
</body>
2.利用 new Object() 创建
<body><script>const obj = new Object({uname: '一个人'})console.log(obj)</script>
</body>
3.利用构造函数创建
<body><script>function Person(uname, age) {this.name = uname,this.age = age}const first = new Person('张三', 18)const second = new Person('李四', 20)console.log(first)</script>
</body>

(二)利用构造函数创建对象

1.构造函数介绍

构造函数是一种特殊的函数用来初始化对象,用来快速创建多个类似的对象

2.约定

函数名开头大写,函数内部用 this,指向被创建的对象

使用 new 关键字调用函数的行为被称为实例化

实例化构造参数时没有参数可以省略()

函数内部 不需要 return 返回值是新创建的对象

<body><script>function Person(uname, age) {this.name = uname,this.age = age}const first = new Person('张三', 18)const second = new Person('李四', 20)console.log(first)</script>
</body>
3.实例化执行过程

创建新对象:只要有 new 出现就立即创建一个对象

构造函数 this 指向新创建的对象

执行构造函数代码,修改 this,添加新的属性 this.属性名 这个属性名就是我们自己添加的

返回新对象

(三)实例成员 & 静态成员

1.实例成员

通过构造函数创建的对象成为实例对象,实例对象中的属性(实例属性)和方法(实例方法)称为

实例成员

说明:

为构造函数传入参数,创建结构相同但是值不同的对象

构造函数创建的实例对象彼此独立互不影响

<body><script>function Person(name) {this.name = name}const laoshi = new Person('一个人')const tongxue = new Person('我是学生')laoshi.name = '我是老师'tongxue.name = '我是一个好学生'console.log(laoshi)console.log(tongxue)</script>
</body>
2.静态成员

构造函数中的属性(静态属性)和方法(静态方法)称作静态成员

说明:

静态成员只能通过构造函数来访问

<body><script>function Person(name) {this.name = name}Person.age = 2Person.add = function (a, b) {return a + b}console.log(Person.age)</script>
</body>

(四)内置构造函数

这段复习一下前面的知识

基本数据类型:字符串,数值,布尔,undefined,null

引用数据类型:对象

js 底层会将基本数据类型创建成对象,因此可以调用相应的属性和方法

<body><script>const str = 'pink'// const str = new String('pink') 实际上是创建了个基本数据类型的对象console.log(str.length)const num = 12console.log(num.toFixed(2))</script>
</body>
1.包装类型:

String Number Boolean 等类型数据是 js 底层使用Object 构造函数包装好的,所以被称为包装类型

String:

是内置的构造函数

length:

实例属性 获得字符串的长度

split(): 拆分成数组

语法:split('分隔符'):

将字符拆分成数组,和 join() 正好相反

<body><script>const str = '我是-一个人'const arr = str.split('-')console.log(arr)</script>
</body>
substring(): 截取

语法:substring(开始的索引号[,结束的索引号])

字符串的截取,如果省略后面默认的结束所引号,就默认截取到最后

如果有结束索引号,结束索引号不包括在截取范围内,要再往后一个

下面就截取了数字一

<body><script>const str = '我是一个人'console.log(str.substring(2, 3))</script>
</body>
 startsWith():是否以...开始

 语法:startsWith(要搜索的字符串[,在字符串中搜索开始的位置])

<body><script>const str = '我是一个人'console.log(str.startsWith('我是'))</script>
</body>
includes(): 是否拥有...

区分大小写

 语法:includes (要搜索的字符串[,在字符串中搜索开始的位置])

<body><script>const str = '我是一个人'console.log(str.includes('是一'))</script>
</body>
 Number:

是内置的构造函数,用于创建数值

toFixed(): 小数位

语法:toFixed(保留小数位数)

<body><script>const num = 10.156console.log(num.toFixed(2))</script>
</body>
2.引用类型:

Object,Array,RegExp,Date 等

Object:

是内置的构造函数,用于创建普通对象,创建不建议用这个,用字面量创建比较好

常用的静态方法:

获得对象中的所有的属性

原本我们用的方法是用for in遍历

<body><script>const person = {name: '一个人',age: 16}for (k in person) {console.log(k)console.log(person[k])}</script>
</body>

 现在我们用的方法是用 Obejct 里面的静态方法

Object.keys(对象名)  获得对象中的所有键

Object.values(对象名) 获得对象中的所有属性值

注意:返回的是数组

<body><script>const person = {name: '一个人',age: 16}console.log(Object.keys(person))console.log(Object.values(person))</script>
</body>
拷贝操作

将一个对象中的内容拷贝给另一个对象

<body><script>const person = {name: '一个人',age: 16}const person1 = {}Object.assign(person1,person)console.log(person1)</script>
</body>

也可利用拷贝给一个对象添加属性

<body><script>const person = {}Object.assign(person,{name:'一个人'})console.log(person)</script>
</body>
Array:

内置构造函数用于创建数组,创建不建议用这个,用字面量创建比较好

遍历数组 forEach
过滤数组 filter
迭代数组 map
累计器 reduce

返回累计处理的结果,常用于求和

语法:数组名.reduce(function(上一次值,当前值){ },初始值)

无初始值时:

<body><script>const arr = [5, 8, 10]const total = arr.reduce(function (prev, current) {return prev + current})console.log(total)</script>
</body>

有初始值时:最后加上初始值就行

<body><script>const arr = [5, 8, 10]const total = arr.reduce(function (prev, current){return prev + current}, 10)console.log(total)</script>
</body>
<body><script>const arr = [5, 8, 10]const total = arr.reduce((prev, current)=>prev + current, 10)console.log(total)</script>
</body>

reduce执行过程:

无起始值时:

第一次循环: prev 第一次数组中的第一个值 5 current 当前值是 8 返回值是 13

第二次循环: prev 是上一次的返回值 13 current  当前值是 10 返回值是 23

有起始值时:

起始值就是上一次值 prev

伪数组转化成真数组

Array.from()

其他方法:

join(): 将数组元素拼为字符串,返回字符串

find(): 返回数组中满足提供的测试函数的第一个返回值,就是用于找到含有某个元素的第一个对象

<body><script>const str = [{name: '华为',price: 10000}, {name: '小米',price: 1000}]const mi = str.find(function(item){return item.name === '小米'})console.log(mi)</script>
</body>d

 every(): 检测数组中是否所有元素都满足指定条件,如果都通过返回 true ,如果都不通过返回 false

some():和 every同理 some 是有一个就行返回 true

<body><script>const arr = [10, 20, 30]const flag = arr.every(item => item >= 10)console.log(flag)</script>
</body>

练习:利用构造函数创建多个对象

界面展示:

代码部分:

<!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>function Goods(name, price, count) {this.name = name,this.price = price,this.count = count}const xiaomi = new Goods('小米', 1999, 20)const huawei = new Goods('华为', 3999, 59)const vivo = new Goods('vivo', 1888, 100)console.log(xiaomi)console.log(huawei)console.log(vivo)</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><div></div><script>const spec = { size: '40cm*40cm', color: '黑色' }const div = document.querySelector('div')div.innerHTML = Object.values(spec).join('/')</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>
<div></div><script>const gift = '50g的茶叶,清洗球'const str = gift.split(',').map(item =>{return `<span>【精品】${item}</span> <br>`}).join('')document.querySelector('div').innerHTML = str</script>
</body></html>

综合练习:购物车

界面展示:

代码部分:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>* {margin: 0;padding: 0;box-sizing: border-box;}.list {width: 990px;margin: 100px auto 0;}.item {padding: 15px;transition: all .5s;display: flex;border-top: 1px solid #e4e4e4;}.item:nth-child(4n) {margin-left: 0;}.item:hover {cursor: pointer;background-color: #f5f5f5;}.item img {width: 80px;height: 80px;margin-right: 10px;}.item .name {font-size: 18px;margin-right: 10px;color: #333;flex: 2;}.item .name .tag {display: block;padding: 2px;font-size: 12px;color: #999;}.item .price,.item .sub-total {font-size: 18px;color: firebrick;flex: 1;}.item .price::before,.item .sub-total::before,.amount::before {content: "¥";font-size: 12px;}.item .spec {flex: 2;color: #888;font-size: 14px;}.item .count {flex: 1;color: #aaa;}.total {width: 990px;margin: 0 auto;display: flex;justify-content: flex-end;border-top: 1px solid #e4e4e4;padding: 20px;}.total .amount {font-size: 18px;color: firebrick;font-weight: bold;margin-right: 50px;}</style>
</head><body><div class="list"><!-- <div class="item"><img src="https://yanxuan-item.nosdn.127.net/84a59ff9c58a77032564e61f716846d6.jpg" alt=""><p class="name">称心如意手摇咖啡磨豆机咖啡豆研磨机 <span class="tag">【赠品】10优惠券</span></p><p class="spec">白色/10寸</p><p class="price">289.90</p><p class="count">x2</p><p class="sub-total">579.80</p></div> --></div><div class="total"><div>合计:<span class="amount">1000.00</span></div></div><script>const goodsList = [{id: '4001172',name: '称心如意手摇咖啡磨豆机咖啡豆研磨机',price: 289.9,picture: 'https://yanxuan-item.nosdn.127.net/84a59ff9c58a77032564e61f716846d6.jpg',count: 2,spec: { color: '白色' }},{id: '4001009',name: '竹制干泡茶盘正方形沥水茶台品茶盘',price: 109.8,picture: 'https://yanxuan-item.nosdn.127.net/2d942d6bc94f1e230763e1a5a3b379e1.png',count: 3,spec: { size: '40cm*40cm', color: '黑色' }},{id: '4001874',name: '古法温酒汝瓷酒具套装白酒杯莲花温酒器',price: 488,picture: 'https://yanxuan-item.nosdn.127.net/44e51622800e4fceb6bee8e616da85fd.png',count: 1,spec: { color: '青色', sum: '一大四小' }},{id: '4001649',name: '大师监制龙泉青瓷茶叶罐',price: 139,picture: 'https://yanxuan-item.nosdn.127.net/4356c9fc150753775fe56b465314f1eb.png',count: 1,spec: { size: '小号', color: '紫色' },gift: '50g茶叶,清洗球'}]const str = goodsList.map(item => {const { name, price, picture, count, spec, gift } = itemconst text = gift ? gift.split(',').map(item => `<span class="tag">${item}</span>`).join('') : ''return ` <div class="item"><img src="${picture}" alt=""><p class="name">${name}${text}</p><p class="spec">${(Object.values(spec)).join('/')}</p><p class="price">${price}</p><p class="count">${'×' + count}</p><p class="sub-total">${(price * count).toFixed(2)}</p></div>`})document.querySelector('.list').innerHTML = strconst total = goodsList.reduce((prev, item) => prev + (item.price * item.count * 100) / 100, 0)document.querySelector('.amount').innerHTML = total.toFixed(2)</script>
</body></html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/782936.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

opengl草稿复习,承上启下(一)

目录 1、链接文件夹中的cpp 2、链接资源到输出目录 3、多编译目标 4、cmakelist添加库 4、添加glfw和glad 5、glfw运行 6、NDC、VBO、VAO 7、渐变三角形 8、渲染两个三角形 9、渲染两个三角形&#xff0c;同时基于原来颜色进行渐变 10、三角形渲染模块化 11、纹理渲…

Python API(happybase)操作Hbase案例

一、Windows下安装Python库&#xff1a;happybase pip install happybase -i https://pypi.tuna.tsinghua.edu.cn/simple 二、 开启HBase的Thrift服务 想要使用Python API连接HBase&#xff0c;需要开启HBase的Thrift服务。所以&#xff0c;在Linux服务器上&#xff0c;执行如…

Kerberos 认证 javax.security.auth.logon.LoginException:拒绝链接 (Connection refused)

kerberos 服务重启之后异常 项目中用到了hive 和hdfs &#xff0c;权限认证使用了Kerberos&#xff0c;因为机房异常&#xff0c;导致了Kerberos 服务重启&#xff0c;结果发现本来运行正常的应用服务hive 和hdfs 认证失败&#xff0c;报错信息是 典型的网络连接异常 排查思路…

动手学机器学习初探机器学习+习题

初探机器学习 “两只手”代表的是人工智能可以做的两大类任务&#xff0c;即预测与决策。 “四条腿”则代表支撑人工智能的四大类科学技术&#xff0c;包括搜索、推理、学习和博弈。 非参数化模型&#xff08;nonparametric model&#xff09;&#xff1a;与参数化模型相反&…

二、分布式事务

目录 二、分布式事务2.1 什么是分布式事务2.2 分布式事务产生的背景2.3 分布式事务产生的场景2.4 分布式事务理论4.1 CAP理论4.2 Base理论 5、分布式事务的解决方案 二、分布式事务 2.1 什么是分布式事务 一组操作会产⽣多个数据库session会话 此时就会出现分布式事务 2.2 分…

我的第一个 VTK 程序

我的第一个 VTK 程序 我的第一个 VTK 程序VTK 可视化流程源程序运行结果 我的第一个 VTK 程序 环境&#xff1a; Visual Studio 2022 CommumityQt 6.2.3 MSVC2019 64位VTK 9.3.0 不会Cmake编译VTK库&#xff1f;看这个&#xff1a;使用 Cmake 对 VTK-9.3.0 进行编译 不会在…

Apache Hive的基本使用语法(一)

一、数据库操作 创建数据库 create database if not exists myhive;查看数据库 use myhive; desc database myhive;创建数据库并指定hdfs存储 create database myhive2 location /myhive2;删除空数据库&#xff08;如果有表会报错&#xff09; drop database myhive;…

基于jsp+mysql+Spring的SpringBoot招聘网站项目

基于jspmysqlSpring的SpringBoot招聘网站项目&#xff08;完整源码sql&#xff09;主要实现了管理员登录,简历管理,问答管理,职位管理,用户管理,职位申请进度更新,查看简历 博主介绍&#xff1a;多年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀…

同一个主机配置多个SSH key

使用git时&#xff0c;我们可能一个git客户端使用多个git服务器&#xff0c;比如github&#xff0c;自建gitlab&#xff0c;gitee&#xff0c;为了防止提交混乱&#xff0c;所以需要一一对应生成公私钥。 第一步&#xff1a; 使用ssh-keygen生成多对密钥对&#xff0c;比如&…

静态NAT配置

静态NAT配置 配置命令&#xff08;详细&#xff09;&#xff1a;ip nat inside source static 协议 内部IP地址 端口 外部IP地址 端口 extendable 例如下图&#xff1a; 配置命令&#xff1a; 第一步&#xff08;说明通告地址&#xff09;&#xff1a;ip nat inside source sta…

Chrome浏览器 安装Vue插件vue-devtools

前言 vue-devtools 是一个为 Vue.js 开发者设计的 Chrome 插件。它可以让你更轻松地审查和调试 Vue 应用程序。与普通的浏览器控制台工具不同&#xff0c;Vue.js devtools 专为 Vue 的响应性数据和组件结构量身定做。 1. 功能介绍 组件树浏览&#xff1a;这个功能可以让你查…

信息工程大学第五届超越杯程序设计竞赛(同步赛)题解

比赛传送门 博客园传送门 c 模板框架 #pragma GCC optimize(3,"Ofast","inline") #include<bits/stdc.h> #define rep(i,a,b) for (int ia;i<b;i) #define per(i,a,b) for (int ia;i>b;--i) #define se second #define fi first #define e…

babyAGI(3)-COOPERATIVE_MODE

babyAGI中有cooperative模式&#xff0c;其核心是调用ray库&#xff0c;实现分布式多进程执行任务。 从BabyAGI的源码中&#xff0c;我们可以学习ray core的使用。 1. Ray核心概念 1.1 Tasks Ray 允许在单独的 Python 工作线程上异步执行任意函数。 这些异步执行的函数被称为…

JavaSE:继承和多态(下篇)

目录 一、前言 二、多态 &#xff08;一&#xff09;多态的概念 &#xff08;二&#xff09;多态实现条件 &#xff08;三&#xff09;多态的优缺点 三、重写 &#xff08;一&#xff09;重写的概念 &#xff08;二&#xff09;重写的规则 &#xff08;三&#xff09;重…

Ubuntu上安装d4rl数据集

Ubuntu上安装d4rl数据集 D4RL的官方 github: https://github.com/Farama-Foundation/D4RL 一、安装Mujoco 1.1 官网下载mujoco210文件 如果装过可以跳过这步 链接&#xff1a;https://github.com/deepmind/mujoco/releases/tag/2.1.0 下载第一个文件即可。我这里是在windo…

专升本-信息安全

信息安全&#xff1a; 1.信息安全的基本属性&#xff1a;保密性&#xff0c;完整性&#xff0c;可用性 信息本身的安全是指保证信息的保密性&#xff08;非授权用户不能访问信息&#xff09;&#xff0c;完整性&#xff08;信息正确&#xff0c;完整&#xff0c;违背篡改&…

win10怎么设置屏幕保护,win10设置屏幕保护方法

电脑屏幕保护的作用主要有三个,第一,可以防止电脑因无人操作而使显示器长时间显示同一个画面,导致加速老化而缩短显示器寿命。第二,防止你离开电脑后屏幕上的隐私被偷窥。第三,大幅度降低屏幕亮度,有一定的省电作用。而Win10系统中呢是可以设置屏幕保护的,如果你想了解具…

uniapp微信小程序消息订阅详解

一、微信公众平台申请订阅模板 注意&#xff1a;订阅信息 这个事件 是 当用户 点击的时候触发 或者 是 支付成功后触发&#xff0c; 用户勾选 “总是保持以上选择&#xff0c;不再询问” 之后或长期订阅&#xff0c;下次订阅调用 wx.requestSubscribeMessage 不会弹窗&#xf…

【最后一天!】月底 京东云服务器特价 价格更低 幻兽帕鲁、雾锁王国 32G仅210/3个月

本文纯原创&#xff0c;侵权必究 【云服务器推荐】价格对比&#xff01;阿里云 京东云 腾讯云 选购指南视频截图 《最新对比表》已更新在文章头部—腾讯云文档&#xff0c;文章具有时效性&#xff0c;请以腾讯文档为准&#xff01; 【腾讯文档实时更新】2024年-幻兽帕鲁服务器…

这次彻底搞懂类加载器吧!!!

一、类加载过程 类加载过程分为&#xff1a;加载->链接->初始化 链接过程具体细分为&#xff1a;验证->准备->解析 二、类加载器 1、定义 类加载器是一个加载类的对象&#xff0c;它工作在类加载过程中的加载这一步&#xff0c;通过类的全类名获得该类的二进制…