惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

S
Schneier on Security
有赞技术团队
有赞技术团队
T
The Blog of Author Tim Ferriss
F
Fortinet All Blogs
D
DataBreaches.Net
F
Full Disclosure
腾讯CDC
博客园 - 【当耐特】
MyScale Blog
MyScale Blog
Stack Overflow Blog
Stack Overflow Blog
小众软件
小众软件
Hugging Face - Blog
Hugging Face - Blog
Last Week in AI
Last Week in AI
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
爱范儿
爱范儿
The GitHub Blog
The GitHub Blog
Engineering at Meta
Engineering at Meta
大猫的无限游戏
大猫的无限游戏
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
S
SegmentFault 最新的问题
The Register - Security
The Register - Security
WordPress大学
WordPress大学
博客园 - 聂微东
雷峰网
雷峰网
J
Java Code Geeks
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
P
Privacy International News Feed
酷 壳 – CoolShell
酷 壳 – CoolShell
A
Arctic Wolf
Scott Helme
Scott Helme
C
Cyber Attacks, Cyber Crime and Cyber Security
T
Tor Project blog
博客园 - 三生石上(FineUI控件)
Know Your Adversary
Know Your Adversary
AWS News Blog
AWS News Blog
G
Google Developers Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
C
CERT Recently Published Vulnerability Notes
O
OpenAI News
Project Zero
Project Zero
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
Application and Cybersecurity Blog
Application and Cybersecurity Blog
云风的 BLOG
云风的 BLOG
N
News and Events Feed by Topic
MongoDB | Blog
MongoDB | Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
Microsoft Security Blog
Microsoft Security Blog
Cisco Talos Blog
Cisco Talos Blog
P
Palo Alto Networks Blog
Schneier on Security
Schneier on Security

博客园 - springsnow

npoi读取word 内容控件 Vue3中 watch、watchEffect 详解 如何使用 Vue SFC Playground toRefs学习 Vue3中如何响应式解构 props useTemplateRef使用 以后台方式启动RealVNC 在VS2022和VS2012共存的电脑上安装VS212扩展注意事项 VS中配置AnkhSVN源代码比较文件排列方式 使用VSCode撰写和发布博客园文章 DBever导入越南文Excel 使用metaWebBlog接口实现博客文章同步 .Net Core3.1上用EFCore的反向工程生成 水淼·文件批量处理器 如何高效的在博客园上编写MD格式的博客(插件pycnblog,推荐) 自动备份软件 —— Syncovery 7.98s Pro、Enterprise VMware 第三方百度网盘客户端 PanDownload、速盘、panlight 本地电脑视频播放器推荐PotPlayer、KMPlayer
复制对象中的一部分属性给另一个对象(对象部分属性解构到新对象)
springsnow · 2023-06-21 · via 博客园 - springsnow

复制对象中的一部分属性给另一个对象(对象部分属性解构到新对象)

点击查看代码
const obj = {
  a: 1,
  b: 2,
  c: 3,
};

//第1种,全部赋值
const new_obj={}
for(let key in obj) {
    new_obj[key] = obj[key]
}
console.log(new_obj);  { a:1, b:2, c:3 }

//第2种,正常取值法
const new_obj = {
 a1: obj.a,
  b: obj.b,
};
console.log(new_obj);  { a1:1, b:2 }

//第3种,利用匿名方法以及 ES6 解构赋值(自执行函数)
const new_obj = (  ({  a, b }) => ({ a1:a, b })  )(obj);
console.log(new_obj);  { a1:1, b:2 }

//第4种,利用 ES6 解构赋值
const { a, b } = obj;
const new_obj = { a1:a, b };
console.log(new_obj);  { a1:1, b:2 }

//第5种,利用 JSON.stringify 第二个参数取值
const new_obj = JSON.parse(JSON.stringify(obj, ["a", "b"]));
console.log(new_obj);  { a:1, b:2 }

//第6种,利用 ES6 解构剔除无用对象
const { c, ...new_obj } = obj;
console.log(new_obj);  { a:1, b:2 }

//第7种,reduce函数
const new_obj = ['a', 'b'].reduce((total, val) => (val in obj && (total[val] = obj[val]), total), {});
console.log(new_obj);  { a:1, b:2 }