JavaScript进阶编程笔记

218次阅读
没有评论

共计 4043 个字符,预计需要花费 11 分钟才能阅读完成。

函数

动态参数

arguments 是函数内部内置的伪数组变量,它包含了调用函数时传入的所有实参。

function sum() {
  let s = 0
  for (let i = 0; i < arguments.length; i++) {s += arguments[i]
  }
  console.log(s)
}
sum(1, 3, 5)

剩余参数

… 是语法符号,用于获取多余的实参,是个真数组。实际开发中,推荐使用剩余参数。

function sum(a, b, ...other) {
  let s = a + b
  for (let i = 0; i < other.length; i++) {s += other[i]
  }
  console.log(s)
}
sum(1, 3, 5, 7)

箭头函数 this

箭头函数没有自己的 this,它的 this 由外层作用域决定,只会从自己作用域链上一层沿用 this。所以说,箭头函数的 this 和它的调用方式无关。

如果直接在箭头后设置对象字面量为返回值时,对象字面量必须使用 () 括起来。

const fn = () => ({ name: '李小龙'})
console.log(fn())

根据函数调用方式的不同,this 值也不同:

  • 以函数形式调用,this 是 window
  • 以方法形式调用,this 是调用方法的对象
  • 构造函数中,this 是新建对象
  • 箭头函数没有自己的 this,由外层作用域决定
  • 通过 call 和 apply 调用的函数,它们的第一个参数就是函数的 this
  • 通过 bind 返回的函数,this 由 bind 第一个参数决定(无法修改)

箭头函数没有自己的 this,所以无法通过 call、apply 和 bind 修改它的 this,箭头函数中也没有 arguments。

内置构造函数

Object

const obj = {name: "佩奇", age: 12}
console.log(Object.keys(obj)) //['name', 'age']
console.log(Object.values(obj)) //['佩奇', 12]

Object.assign(obj, { sex: "女"}) // 拷贝对象
console.log(obj) //{name: '佩奇', age: 12, sex: '女'}

Array

filter,筛选数组

const arr = [1, 4, 7, 9]
const newArr = arr.filter(function (value, index) {return value > 5})
console.log(newArr) //[7, 9]

reduce

const arr = [1, 3, 5]
const total = arr.reduce(function (prev, current) {return prev + current})
console.log(total) //9

// 有初始值
const total2 = arr.reduce(function (prev, current) {return prev + current}, 10)
console.log(total2) //19

// 箭头函数写法
const total3 = arr.reduce((prev, current) => prev + current, 10)
console.log(total3) //19

find,找到就返回。

const arr = [{ name: "佩奇", age: 18},
  {name: "乔治", age: 16},
]
const p = arr.find(function (item) {return item.name === "佩奇"})
console.log(p) //{name: '佩奇', age: 18}

findIndex()用于找出第一个符合条件的数组成员的位置,如果没有找到返回 -1。

some,有一个符合条件就返回 true,否则返回 false。

const arr = [1, 4, 7, 9]
const flag = arr.some(function (value, index) {return value > 5})
console.log(flag) //true

注意:在 some 里面遇到 return true 会终止遍历,迭代效率更高。

every,每一个是否都符合条件,都符合返回 true,否则返回 false。

const arr = [1, 5, 8]
const flag = arr.every((item) => item >= 1)
console.log(flag) //true

from,把伪数组转换为真数组。

const lst = document.querySelectorAll("ul li")
const lst2 = Array.from(lst)
console.log(lst2)

String

const str = "佩奇, 乔治"
const arr = str.split(",")
console.log(arr) //['佩奇', '乔治']

console.log(str.substring(2)) //, 乔治
console.log(str.substring(3, 5)) // 乔治

console.log(str.startsWith("佩奇")) //true

console.log(str.includes("佩奇")) //true

深浅拷贝

浅拷贝

如果是简单数据类型拷贝值,引用数据类型拷贝的是地址(简单理解,如果是单层对象,没问题,如果有多层就有问题)。

const obj = {
  name: "佩奇",
  age: 10,
}
// 方法一
const obj2 = {...obj}
obj2.age = 12
console.log(obj.age) //10
console.log(obj2.age) //12
// 方法二
const obj3 = {}
Object.assign(obj3, obj)
obj3.age = 14
console.log(obj.age) //10
console.log(obj3.age) //14

const arr = [{age: 18}, {age: 20}]
const arr2 = arr.slice() // 浅拷贝
const arr3 = structuredClone(arr) // 深拷贝
console.log(arr2[0] === arr[0]) //true
console.log(arr3[0] === arr[0]) //false

深拷贝

方法一,递归实现:

const obj = {
  name: "佩奇",
  age: 10,
  hobby: ["唱歌", "跳舞"],
}
function deepCopy(newObj, oldObj) {for (let k in oldObj) {if (oldObj[k] instanceof Array) {newObj[k] = []
      deepCopy(newObj[k], oldObj[k])
    } else if (oldObj[k] instanceof Object) {newObj[k] = {}
      deepCopy(newObj[k], oldObj[k])
    } else {newObj[k] = oldObj[k]
    }
  }
}
const obj2 = {}
deepCopy(obj2, obj)
obj2.hobby[0] = "睡觉"
console.log(obj.hobby[0]) // 唱歌

方法二,使用 js 库 lodash 里面的 cloneDeep 实现:

<script src="https://cdn.bootcdn.net/ajax/libs/lodash.js/4.17.21/lodash.min.js"></script>
<script>
  const obj = {
    name: "佩奇",
    age: 10,
    hobby: ["唱歌", "跳舞"],
  }
  const obj2 = _.cloneDeep(obj)
  obj2.hobby[0] = "睡觉"
  console.log(obj.hobby[0]) // 唱歌
</script>

方法三,使用 JSON 字符串转换实现:

const obj = {
  name: "佩奇",
  age: 10,
  hobby: ["唱歌", "跳舞"],
}
const obj2 = JSON.parse(JSON.stringify(obj))
obj2.hobby[0] = "睡觉"
console.log(obj.hobby[0]) // 唱歌

Map

Map 用来存储键值对结构的数据 (key-value)。

Map 和 Object 的主要区别:

  • Object 中的属性名只能是字符串。如果传递了一个其他类型的属性名,JS 解释器会自动将其转换为字符串
  • Map 中任何类型值都可作为 key

属性和方法:

  • map.size()获取 map 中键值对的数量
  • map.set(key,value)向 map 中添加键值对
  • map.get(key)根据 key 获取值
  • map.delete(key)删除指定数据
  • map.has(key)检查 map 中是否包含指定键
  • map.clear()删除全部的键值对
const map = new Map() // 空 Map
map.set('name', '李小龙') // 添加 key-value
console.log(map.has('name')) // true 是否存在 key
map.set(NaN, '呵呵')
console.log(map.get(NaN)) // 呵呵 获取 value
map.delete(NaN) // 删除 key
console.log(map) // Map(1) {'name' => '李小龙'}

// Map 转数组
const arr = Array.from(map) // 方法一
const arr2 = [...map] // 方法二

// 数组转 Map
const map2 = new Map([['name', '猪八戒'],
  ['age', 18],
])
console.log(map2) //{'name' => '猪八戒', 'age' => 18}

Set

用来创建一个集合,功能和数组类似,不同点在于 Set 中不能存储重复数据。

方法:

  • size 获取数量
  • add()添加元素
  • has()检查元素
  • delete()删除元素
const set = new Set()
set.add(1)
set.add('李小龙')
console.log(set) //{1, '李小龙'}

正文完
 0
阿伯手记
版权声明:本站原创文章,由 阿伯手记 于2023-08-02发表,共计4043字。
转载说明:本站原创内容,除特殊说明外,均基于 CC BY-NC-SA 4.0 协议发布,转载须注明出处与链接。
评论(没有评论)
验证码

阿伯手记

阿伯手记
阿伯手记
喜欢编程,头发渐稀;成长路上,宝藏满地
文章数
766
评论数
204
阅读量
446092
今日一言
-「
热门文章
职场救急!AI请假话术生成器:1秒定制高通过率理由

职场救急!AI请假话术生成器:1秒定制高通过率理由

超级借口 不好开口?借口交给我!智能生成工作请假、上学请假、饭局爽约、约会拒绝、邀约推辞、万能借口等各种借口理...
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
巴别英语:用美剧和TED演讲轻松提升英语听力与口语

巴别英语:用美剧和TED演讲轻松提升英语听力与口语

还在为枯燥的英语学习而烦恼吗?巴别英语通过创新的美剧学习模式,让英语学习变得生动有趣。平台提供海量美剧和 TE...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
TVAPP:开源电视盒子资源库,一键打造家庭影院

TVAPP:开源电视盒子资源库,一键打造家庭影院

导语 TVAPP 是一个专为 Android TV 电视盒子用户打造的开源影音资源库,集成了影视、直播、游戏等...
2025年12月 每日精选

2025年12月 每日精选

关于每日精选栏目 发现一些不错的资源,点击 这里 快速投稿。 12 月 26 日 .ax 顶级域 目前全球唯一...
最新评论
15220202929 15220202929 怎么用
八对 八对 麻烦大佬更新下【堆新】的友链站名:八对星星描述:极目星视穹苍无界•足履行者大地有疆链接:https://8dui.com图标:https://cf.8dui.com/logo.webp横标:https://cf.8dui.com/logo-w.webp订阅:https://8dui.com/rss.xml
三毛笔记 三毛笔记 已添加
DUINEW DUINEW 已添加贵站,期待贵站友链~博客名称:堆新博客地址:https://duinew.com/博客描述:堆新堆新,引力向新!——堆新(DUINEW)博客头像:https://d.duinew.com/logo.webp横版头像:https://d.duinew.com/logo-w.webp博客订阅:https://duinew.com/rss.xml
hedp hedp 没看懂
bingo bingo 直接生成就可以啦,也可以添加一些选项
满心 满心 申请更新下友联信息,原名:满心记,现名:周天记原域名:qq.mba,现域名:zhoutian.com描述:我在人间混日子
开业吉日 开业吉日 没看明白这个怎么用
开业吉日 开业吉日 beddystories 这个网站太赞了,收藏
热评文章
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
清华大学官方免费DeepSeek教程

清华大学官方免费DeepSeek教程

AI 领域近期最引人注目的焦点当属 DeepSeek,这款由中国创新企业深度求索研发的人工智能工具,正以开放源...
Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 是一款基于 Fastify、Vercel 和 Supabase 构建的 URL 缩短服务...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 是一个致力于为儿童提供优质睡前故事的在线平台,用户可以在这里找到来自世界各地的经典故...
DrawLink:一键生成链接视觉卡片,提升分享点击率

DrawLink:一键生成链接视觉卡片,提升分享点击率

小贴士 :此站或已变迁,但探索不止步。我们已为您备好「类似网站」精选合集,相信其中的发现同样能为您带来惊喜。