JavaScript进阶之道

JavaScript进阶之道

repo: github.com/alphardex/p…

Python和JavaScript在笔者看来是很相似的语言,本文归纳了JavaScript的各种tricks,相对于之前的Python版

两篇文章都读完,有没有发现它们的目录结构是一个样的呢XD

基本

模板字符串

let name = 'alphardex'
`Ore wa ${name} desu, ${
     4 * 6} sai, gakusei desu.`
// "Ore wa desu, 24 sai, gakusei desu."
复制代码

三元运算符

// if(condition){
    
// fuck
// } else {
    
// shit
// }
(condition)? fuck: shit
复制代码

字符串的拼接,反转与分割

let letters = ['咚', '哒', '呦', '!']
letters.join('')
// "咚哒呦!"
letters.reverse()
// ["!", "呦", "哒", "咚"]
let name = 'fujiwara chika'
name.split(' ')
// ["fujiwara", "chika"]
复制代码

判断元素的存在性

'fuck you'.includes('fuck')
// true
['bitch', 'whore'].includes('slut')
// false
'company' in {
   'title': 'Kaguya-sama: love is war', 'company': 'A1 Pictures'}
// true
复制代码

函数

箭头函数

函数的简化写法,配合map、filter、sort等实现函数式编程

// function foo(parameters){
    
// return expression
// }
let foo = (parameters) => expression
复制代码

map – 映射

let numbers = [1, 2, 3, 4, 5]
numbers.map(e=>e ** 2)
// [1, 4, 9, 16, 25]
复制代码

filter – 过滤

let values = [null, undefined, NaN, 0, '', true, 'alphardex', 666]
values.filter(e=>e)
// [true, "alphardex", 666]
复制代码

sort – 排序

let numbers = [4, 2, 5, 1, 3]
numbers.sort((a, b)=>a-b) // 升序
// [1, 2, 3, 4, 5]
numbers.sort((a, b)=>b-a) // 降序
// [5, 4, 3, 2, 1]
复制代码

其他骚操作

求1到100的和

[...Array(101).keys()].reduce((a, b)=>a+b)
// 5050
// 或者用lodash实现,写法简直跟Python一模一样
// _.sum(_.range(101))
复制代码

扁平化数组

const flatten = (arr, depth=1) => arr.reduce((a, v)=>a.concat(depth>1 && Array.isArray(v)?flatten(v, depth-1):v), [])
let arr = [1, [2, 3, ['a', 'b', 4], 5], 6]
flatten(arr, 2)
// [1, 2, 3, "a", "b", 4, 5, 6]
// 或者用ES10新增的flat
// arr.flat(2)
复制代码

扩展运算符

数据结构的合并

let arr1 = ['kaguya', 'miyuki']
let arr2 = ['chika', 'ishigami']
[...arr1, ...arr2]
// ['kaguya', 'miyuki', 'chika', 'ishigami']
let obj1 = {
   'name': 'rimuru'}
let obj2 = {
   'kind': 'slime'}
{...obj1, ...obj2}
// {name: 'rimuru', kind: 'slime'}
复制代码

函数参数的打包与解包

// 打包
let foo = (...args) => console.log(args)
foo(1, 2)
// [1, 2]
// JS只能打包位置参数,无法正确地打包关键词参数
// foo(name='hayasaka', job='maid')
// ["hayasaka", "maid"] (keyword没了)

// 解包
let divmod = (a, b) => [Math.floor(a/b), a % b]
let t = [10, 3]
let [quotient, remainder] = divmod(...t)
quotient
// 商:3
remainder
// 余:1
复制代码

生成器

只要函数中包含yield关键词,这函数就是一个生成器函数

调用生成器函数时,会返回一个生成器对象

正如yield本身的意思(产出),对生成器对象调用next()会使其不断产出值,直到无值才终止遍历,done属性变为true

function* genHello() {
    yield 'hello'
    yield 'world'
}

g = genHello()
// genHello {<suspended>}
g.next()
// {value: "hello", done: false}
g.next()
// {value: "world", done: false}
g.next()
// {value: undefined, done: true}
复制代码

如果生成器函数需要产出另一个生成器生成的值,就要用到yield*

function* chain(...iterables){
    for(let it of iterables){
        yield* it
    }
}

let s = 'ABC'
let t = [...Array(3).keys()]
[...chain(s, t)]
// ["A", "B", "C", 0, 1, 2]
复制代码

数据结构

数组

同时迭代元素与其索引

相当于Python的enumerate

let li = ['umaru', 'ebina', 'tachibana']
li.map((e, i)=>`${i+1}. ${e}`)
// ['1. umaru', '2. ebina', '3. tachibana']
复制代码

元素的追加与连接

push在末尾追加元素,concat在末尾连接元素

let li = [1, 2, 3]
li.push([4, 5])
li
// [1, 2, 3, [4, 5]]
li.concat([4, 5])
li
// [1, 2, 3, [4, 5], 4, 5]
复制代码

测试是否整体/部分满足条件

every测试所有元素是否都满足于某条件,some则是测试部分元素是否满足于某条件

[1, 2, 3, 4, 5].every(e=>e<20)
// true
[1, 3, 4, 5].some(e=>e%2===0)
// true
复制代码

同时迭代2个以上的数组

相当于Python的zip

let subjects = ['nino', 'miku', 'itsuki']
let predicates = ['saikou', 'ore no yome', 'is sky']
subjects.map((e,i)=>`${e} ${predicates[i]}`)
// ["nino saikou", "miku ore no yome", "itsuki is sky"]
复制代码

去重

利用集合的互异性,同时此法还保留了原先的顺序

let li = [3, 1, 2, 1, 3, 4, 5, 6]
[...new Set(li)]
// [3, 1, 2, 4, 5, 6]
复制代码

解构赋值

最典型的例子就是2数交换

let [a, b] = [b, a]
复制代码

用rest运算符可以获取剩余的元素

let [first, ...rest] = [1, 2, 3, 4]
first
// 1
rest
// [2, 3, 4]
复制代码

对象

遍历

let obj = {
   'name': 'sekiro', 'hobby': 'blacksmithing', 'tendency': 'death'}
Object.keys(obj)
// ["name", "hobby", "tendency"]
Object.values(obj)
// ["sekiro", "blacksmithing", "death"]
Object.entries(obj).map(([key, value])=>`${key}: ${value}`)
// ["name: sekiro", "hobby: blacksmithing", "tendency: death"]
复制代码

排序

let data = [{
   'rank': 2, 'author': 'beta'}, {
   'rank': 1, 'author': 'alpha'}]
data.sort((a, b)=>a.rank - b.rank)
// [{'rank': 1, 'author': 'alpha'}, {'rank': 2, 'author': 'beta'}]
复制代码

反转

let obj = {
   'name': 'sakurajima mai', 'suit': 'bunny girl'}
Object.fromEntries(Object.entries(obj).map(([key, value])=>[value, key]))
// {sakurajima mai: "name", bunny girl: "suit"}
// 或者用lodash实现
// _.invert(obj)
复制代码

缺失键处理

如果键不在字典中,返回一个默认值,类似Python的dict.get

let obj = {
   'name': 'okabe rintaro', 'motto': 'elpsycongroo'}
obj.job || 'mad scientist'
// mad scientist
复制代码

如果键不在字典中,将会添加它并设置一个默认值,类似Python的dict.setdefault

let obj = {
   'name': 'okabe rintaro', 'motto': 'elpsycongroo'}
obj.job = obj.job || 'mad scientist'
// "mad scientist"
obj
// {name: "okabe rintaro", motto: "elpsycongroo", job: "mad scientist"}
复制代码

语言专属特性

待整理

转载于:https://juejin.im/post/5cc45bf5e51d456e671c7e3c

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/100951.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • HTTP和HTTPS协议,看一篇就够了

    HTTP和HTTPS协议,看一篇就够了一、前言:我们上网很简单,只需要通过网络服务商开通端口就可以了,每天都在上网,有留意到访问网站链接有什么共同点吗?为什么需要但是为什么要讲HTTP和HTTPS呢?二、HTTP和HTTPS发展历史当我们打开谷歌浏览器输入www.12306.cn,回车很快在浏览器上就看到页面,其中的浏览器就是客户端,负责接受浏览器的是服务器,两者的通信是通过HTTP协议。什么是HTTP?…

    2022年4月29日
    74
  • java 415_415错误[通俗易懂]

    java 415_415错误[通俗易懂]WhitelabelErrorPageThisapplicationhasnoexplicitmappingfor/error,soyouareseeingthisasafallback.TueNov1314:41:09CST2018Therewasanunexpectederror(type=UnsupportedMediaType,s…

    2022年6月12日
    176
  • nginx php apache php 对比,Apache和nginx的比较「建议收藏」

    nginx php apache php 对比,Apache和nginx的比较「建议收藏」nginx相对apache的优点:● 轻量级,同样起web服务,比apache占用更少的内存及资源● 抗并发,nginx处理请求是异步非阻塞的,而apache则是阻塞型的,在高并发下nginx能保持低资源低消耗高性能● 高度模块化的设计,编写模块相对简单● 社区活跃,各种高性能模块出品迅速啊● Nginx支持更多的并发连接,能够支持高达50000个并发连接数的相应● 能在不间断服务…

    2022年6月6日
    29
  • IntelliJ IDEA 创建Java项目[通俗易懂]

    IntelliJ IDEA 创建Java项目[通俗易懂]Java模块让你可以开发JavaSE和JavaEE应用程序。由Java模块提供的核心功能可通过加入各种技术和框架支持进行扩展。当您创建好一个项目后,您可以创建一个Java模块。您还可以添加一个Java模块到现有项目。注意:这里说的Java模块实际是一个Java项目,而IDEA的项目(Project)则相当于Eclipse的工作空间(workspace)的概念,相当于VS的解决方案(soluti

    2022年9月29日
    4
  • Java十大常用框架介绍

    Java十大常用框架介绍转载:https://www.toutiao.com/a6591434508417892871/?tt_from=copy_link&amp;utm_campaign=client_share&amp;timestamp=1535816836&amp;app=news_article&amp;utm_source=copy_link&amp;iid=42275378268&amp;utm_medi…

    2022年7月8日
    30
  • pycharm python interpreter_python interpreter什么意思

    pycharm python interpreter_python interpreter什么意思1,首先我们肯定要在Pycharm里建立一个新项目,有两个选项,一个建立新的虚拟的环境,一个基于已有的环境这里选择第一项。2,选择第一项之后会有两个解释器,一个虚拟的即location/venv/Scripts/python.exe,另一个需要基解释器即本地解释器/python.exe。关于第一项的解释我极力推荐此篇文章虚拟解释器的简单说明3,然后,如果在创建pycharm项目时项目解…

    2022年8月27日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号