JavaScript 基础五 对象

JavaScript 基础五 对象

  • 1. 对象
  • 2. 对象使用
    • ① 声明语法
    • ② 对象有属性和方法组成
    • ③ 属性
      • 对象属性的增删改查操作
    • ④ 方法
  • 3. 对象遍历
    • 实例
  • 4. 内置对象
    • ① 内置对象
    • ② 内置对象Math
      • 属性
      • 方法

引入:保存网站用户信息,比如姓名、年龄、电话号码,用以前学过的数据类型不方便。

1. 对象

对象 object 是JavaScript里的一种数据类型。
可以理解为一种无序的数据集合,注意数组是有序的数据集合。

let obj = {uname: 'pink',age: 18,gender: '女'
}

对象的特点:
①无序的数据的集合
②可以详细描述某个事物

2. 对象使用

① 声明语法

let 对象名= {}
let 对象名= new Object()

例如 let person= {} 声明了一个person的对象

{}是对象字面量。

对象和null

let obj = {}
typeof obj 是 object
typeof null 是 object
所以也可以 用 let obj  = null 表示这个变量我以后要来存放对象

② 对象有属性和方法组成

属性:信息或特征(名词)。比如手机尺寸、颜色、重量等
方法:功能或行为(动词)。比如手机打电话、发短信、玩游戏等

let 对象名 = {属性名: 属性值,方法名: 函数
}

③ 属性

数据描述性的信息称为属性,如人的姓名、身高、年龄、性别等。

  • 属性都是成对出现的,包括属性名和值,它们之间用英文冒号(:)分隔。
  • 多个属性之间用英文逗号分隔。
  • 属性就是依附在对象上的变量(外面是变量,对象内是属性)
  • 属性名可以使用 双引号或者单引号,一般情况下省略,除非名称遇到特殊符号如空格、中横线等。
  • 对象属性没有顺序。

对象属性的增删改查操作

增删改查
在这里插入图片描述
在这里插入图片描述

对象	['属性名']

④ 方法

数据行为性的信息称为方法,如跑步、唱歌等,一般是动词性的,其本质是函数。

let person = {name: '刘德华',singSong: function() {console.log('冰雨')}count: function(x, y) {console.log(x+y)}
}

方法调用对象名.方法名

person.singSong()

类比 document.wirte()

方法增加也可以和属性增加一样,但是我们一般不这么做:

let user = {}
user.name = 'xiaoming'
user.['age'] = 18//动态添加'对象的方法'
user.move = function() {console.log('移动一点距离')
}

3. 对象遍历

对象里面是无序的键值对,没有规律,不像数组里面有规律的下标。

for in语法

let obj = {name: 'pink',age: 18, gender: '女'
}for(let k in obj) {console.log(k) //获得对象属性是 kconsole.log(obj[k]) //获得对象值是 obj[k]
}

这里不可以写 obj.k。如果是obj.name,那么取出的是name这个属性,但是如果写成了obj.k,取的就是 k 这个属性。当然不仅仅是这么简单,还更因为 key 里面存的是 字符串类型,key 是 ‘name’ 而不是 name

也可以用在数组中,但因为索引是字符串型的,很少会拿这种方式遍历数组。

let arr = ['pink', 'green', 'blue']
for(let k in arr) {console.log(k) //数组的下标 索引号 ,请注意这里打印出来的是字符串类型}

数组对象: 数组的每一个成员都是对象

let students = [{name: '小明', age: 18, gender: '男', hometown: '河北省'} ,{name: '小红', age: 19, gender: '女', hometown: '河男省'} ,{name: '小刚', age: 17, gender: '男', hometown: '山东省'} ,{name: '小丽', age: 18, gender: '女', hometown: '山西省'} 
]for(int i = 0; i < students.length; i++) {console.log(i) //下标索引号console.log(students[i]) //每一个对象for(let k in students[i]) {}
}

实例

在这里插入图片描述

静态写法为:

<!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>
<style>table {width: 600px;text-align: center;}table,th,td {border: 1px solid #ccc;border-collapse: collapse;}caption {font-size: 18px;margin-bottom: 10px;font-weight: 700;}tr {height: 40px;cursor: pointer;}table tr:nth-child(1) {background-color: #ddd;}table tr:not(:first-child):hover {background-color: #eee;}
</style>
<body><table><caption>学生列表</caption><tr><th>序号</th><th>姓名</th><th>年龄</th><th>性别</th><th>家乡</th></tr><tr><td>1</td><td>小明</td><td>18</td><td></td><td>河北省</td></tr><tr><td>2</td><td>小红</td><td>19</td><td></td><td>河南省</td></tr><tr><td>3</td><td>小刚</td><td>17</td><td></td><td>山西省</td></tr><tr><td>4</td><td>小丽</td><td>18</td><td></td><td>山东省</td></tr></table>
</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>
<style>table {width: 600px;text-align: center;}table,th,td {border: 1px solid #ccc;border-collapse: collapse;}caption {font-size: 18px;margin-bottom: 10px;font-weight: 700;}tr {height: 40px;cursor: pointer;}table tr:nth-child(1) {background-color: #ddd;}table tr:not(:first-child):hover {background-color: #eee;}
</style>
<body><table><caption>学生列表</caption><tr><th>序号</th><th>姓名</th><th>年龄</th><th>性别</th><th>家乡</th></tr><script>let students = [{name: '小明', age: 18, gender: '男', hometown: '河北省'} ,{name: '小红', age: 19, gender: '女', hometown: '河男省'} ,{name: '小刚', age: 17, gender: '男', hometown: '山东省'} ,{name: '小丽', age: 18, gender: '女', hometown: '山西省'} ]for(let i = 0; i < students.length; i++) {document.write(`<tr><td>${i+1}</td><td>${students[i].name}</td><td>${students[i].age}</td><td>${students[i].gender}</td><td>${students[i].hometown}</td></tr>`)}</script></table>
</body>
</html>

4. 内置对象

① 内置对象

例如 document.write(), console.log()

② 内置对象Math

Math对象是 JS提供的一个“数学”对象
作用:提供了一系列做数学运算的方法

Math对象包含的方法有:
Ø random:生成0-1之间的随机数(包含0不包括1)
Ø ceil:向上取整
Ø floor:向下取整
Ø max:找最大数
Ø min:找最小数
Ø pow:幂运算
Ø abs:绝对值
Ø Math对象在线文档

属性

  • Math.PI,获取圆周率
// 圆周率
console.log(Math.PI);

方法

  • Math.random,生成 0 到 1 间的随机数
// 0 ~ 1 之间的随机数, 包含 0 不包含 1
Math.random()
  • Math.ceil,数字向上取整
    ceil是天花板的意思。
// 舍弃小数部分,整数部分加1
Math.ceil(3.4) // 4
  • Math.floor,数字向下取整
// 舍弃小数部分,整数部分不变
Math.floor(4.68) // 4
  • 注意区别 parseInt()取整函数
    parseInt可以转化字符
parseInt(1.2) // 1
parseInt('12px') // 12
  • Math.round,四舍五入取整
    小数部分等于0.5会舍入到正方向上相邻的整数。
// 取整,四舍五入原则
Math.round(5.46539)
Math.round(4.849)Math.round(-20.5)
Math.round(-20.51)
  • Math.max,在一组数中找出最大的
// 找出最大值
Math.max(10, 21, 7, 24, 13)
  • Math.min,在一组数中找出最小的
// 找出最小值
Math.min(24, 18, 6, 19, 21)
  • Math.pow,幂方法
// 求某个数的多少次方
Math.pow(4, 2) // 求 4 的 2 次方
Math.pow(2, 3) // 求 2 的 3 次方
  • Math.sqrt,平方根
// 求某数的平方根
Math.sqrt(16)

数学对象提供了比较多的方法,这里不要求强记,通过演示数学对象的使用,加深对对象的理解。

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

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

相关文章

element-ui button 仿写 demo

基于上篇 button 源码分享写了一个简单 demo&#xff0c;在写 demo 的过程中&#xff0c;又发现了一个小细节&#xff0c;分享一下&#xff1a; 1、组件部分&#xff1a; <template><buttonclass"yss-button"click"handleClick":class"[ty…

第二十一回 阎婆大闹郓城县 朱仝义释宋公明-FreeBSD Linux 使用Rsync备份

阎婆状告宋江杀死她女儿阎婆惜&#xff0c;知县有意偏袒宋江&#xff0c;只是一味的拷打唐牛儿&#xff0c;但无奈张三张文远说刀子是宋江的&#xff0c;知县不得已差人拿宋江来审问。第一次没见到人&#xff0c;第二次派朱仝雷横两个人去。 朱仝到地窖里找到了躲藏的宋江&…

使用STM32 DMA实现高效数据传输的设计与优化

使用STM32的DMA功能可以有效地实现高效的数据传输。在下面的解释中&#xff0c;我将介绍如何设计和优化使用STM32 DMA进行高效数据传输的方法。同时&#xff0c;我将提供一些示例代码来帮助您理解和实践。 ✅作者简介&#xff1a;热爱科研的嵌入式开发者&#xff0c;修心和技术…

3.霍夫曼求直线原理与代码(python)

一、原理 我们常用的直线方程是&#xff1b; 对这个公式移项后得到&#xff1b; 其实&#xff0c;当确定时&#xff0c;这条直线就确定了。我对霍夫曼求直线的理解是&#xff1a;在一个二维平面上有很多个点&#xff0c;然后对取不同的值时得到不同的直线&#xff0c;查看二维…

产品经理学习-产品运营《海报制作》

如何策划一款优秀的海报 海报是什么&#xff1f; 是一种将文字和图片结合的信息传递形式&#xff1b;其作用和目的是把想传递给用户的信息高效的传递出去&#xff0c;让用户在极短的时间内产生兴趣&#xff0c;进而产生收藏、分享等行为。 海报的类型&#xff1a; 类型 特点 …

苹果家的脸部电脑终于来啦!

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

jdk17新特性—— record关键字(类似于Lombok功能)

目录 一、record关键字的概述1.1、概述1.2、特性 二、record关键字的代码示例2.1、record关键字代码示例2.2、record关键字代码.class文件示例2.3、record关键字代码示例 总结说明 三、record关键字实现密封接口的代码示例3.1、record关键字实现密封接口的代码示例 四、record关…

LSTM进行情感分析

LSTM进行情感分析的复现–pytorch的实现 关于TextCNN的复现参考本文章 TextCNN的复现–pytorch实现 - 知乎 (zhihu.com) 接下来主要是对代码内容的详解&#xff0c;完整代码将在文章末尾给出。 使用的数据集为电影评论数据集&#xff0c;其中正面数据集5000条左右&#xff…

2024美赛数学建模E题思路+代码

文章目录 1 赛题思路2 美赛比赛日期和时间3 赛题类型4 美赛常见数模问题5 建模资料 1 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 2 美赛比赛日期和时间 比赛开始时间&#xff1a;北京时间2024年2月2日&#xff08;周五&#xff…

IP、端口、网络协议、TCP-IP五层模型

目录 IP地址 端口号 网络协议 协议分层&#xff08;TCP/IP五层模型&#xff09; 应用层 传输层&#xff08;也叫运输层&#xff09; 网络层 数据链路层 物理层 A用户通过qq给B发送一个字符串所经历的过程 IP地址 ip地址是一台主机的网络地址。 ip地址主要是用…

【教程】谈一谈 IPA 上传到 App Store Connect 的几种方法

【教程】谈一谈 IPA 上传到 App Store Connect 的几种方法 引言 在应用开发过程中&#xff0c;将应用程序上传到 App Store Connect 是一个关键的环节。本文将探讨几种常见的 IPA 文件上传方法&#xff0c;包括 Xcode、Application Loader、altool、Appuploader以及Transport…

【React】react组件传参

【React】react组件传参 一、props&#xff1a;父组件向子组件传参1、将普通的参数作为props传递2、将jsx作为props传递&#xff08;组件插槽&#xff09; 二、自定义事件&#xff1a;子父组件向父组件传参三、context进行多级组件传参四、redux全局状态管理 一、props&#xf…