ZiuChen.github.io/article/彻底搞懂对象的数据属性描述符、存储属性描述符.html

93 lines
55 KiB
HTML
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!DOCTYPE html>
<html lang="en-US" dir="ltr">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title>彻底搞懂对象的数据属性描述符、存储属性描述符 | ZiuChen</title>
<meta name="description" content="Unlimited Progress.">
<meta name="generator" content="VitePress v1.5.0">
<link rel="preload stylesheet" href="/assets/style.CSuXXoGY.css" as="style">
<link rel="preload stylesheet" href="/vp-icons.css" as="style">
<script type="module" src="/assets/app.BX5tB7OC.js"></script>
<link rel="preload" href="/assets/inter-roman-latin.Di8DUHzh.woff2" as="font" type="font/woff2" crossorigin="">
<link rel="modulepreload" href="/assets/chunks/theme.BO4U0VLs.js">
<link rel="modulepreload" href="/assets/chunks/framework.D__0zeO9.js">
<link rel="modulepreload" href="/assets/article_彻底搞懂对象的数据属性描述符、存储属性描述符.md.BOJlLhrD.lean.js">
<link rel="icon" href="/logo.png">
<script id="check-dark-mode">(()=>{const e=localStorage.getItem("vitepress-theme-appearance")||"auto",a=window.matchMedia("(prefers-color-scheme: dark)").matches;(!e||e==="auto"?a:e==="dark")&&document.documentElement.classList.add("dark")})();</script>
<script id="check-mac-os">document.documentElement.classList.toggle("mac",/Mac|iPhone|iPod|iPad/i.test(navigator.platform));</script>
</head>
<body>
<div id="app"><div class="Layout" data-v-dc294264><!--[--><!--]--><!--[--><span tabindex="-1" data-v-615afeb8></span><a href="#VPContent" class="VPSkipLink visually-hidden" data-v-615afeb8> Skip to content </a><!--]--><!----><header class="VPNav" data-v-dc294264 data-v-9da3a6e0><div class="VPNavBar" data-v-9da3a6e0 data-v-24334755><div class="wrapper" data-v-24334755><div class="container" data-v-24334755><div class="title" data-v-24334755><div class="VPNavBarTitle has-sidebar" data-v-24334755 data-v-9044da73><a class="title" href="/" data-v-9044da73><!--[--><!--]--><!--[--><img class="VPImage logo" src="/logo.png" alt data-v-1d87296a><!--]--><span data-v-9044da73>ZiuChen</span><!--[--><!--]--></a></div></div><div class="content" data-v-24334755><div class="content-body" data-v-24334755><!--[--><!--]--><div class="VPNavBarSearch search" data-v-24334755><!--[--><!----><div id="docsearch"><button type="button" class="DocSearch DocSearch-Button" aria-label="Search"><span class="DocSearch-Button-Container"><span class="vp-icon DocSearch-Search-Icon"></span><span class="DocSearch-Button-Placeholder">Search</span></span><span class="DocSearch-Button-Keys"><kbd class="DocSearch-Button-Key"></kbd><kbd class="DocSearch-Button-Key">K</kbd></span></button></div><!--]--></div><nav aria-labelledby="main-nav-aria-label" class="VPNavBarMenu menu" data-v-24334755 data-v-13bcb571><span id="main-nav-aria-label" class="visually-hidden" data-v-13bcb571> Main Navigation </span><!--[--><!--[--><a class="VPLink link VPNavBarMenuLink" href="/" tabindex="0" data-v-13bcb571 data-v-30b277b0><!--[--><span data-v-30b277b0>首页</span><!--]--></a><!--]--><!--[--><div class="VPFlyout VPNavBarMenuGroup" data-v-13bcb571 data-v-6c6e0bff><button type="button" class="button" aria-haspopup="true" aria-expanded="false" data-v-6c6e0bff><span class="text" data-v-6c6e0bff><!----><span data-v-6c6e0bff>我的项目</span><span class="vpi-chevron-down text-icon" data-v-6c6e0bff></span></span></button><div class="menu" data-v-6c6e0bff><div class="VPMenu" data-v-6c6e0bff data-v-617b6928><div class="items" data-v-617b6928><!--[--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/project/ClipboardManager/" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>超级剪贴板</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/project/Markdown/" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>超级Markdown</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/project/JSRunner/" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>超级JavaScript</span><!--]--></a></div><!--]--><!--]--></div><!--[--><!--]--></div></div></div><!--]--><!--[--><div class="VPFlyout VPNavBarMenuGroup" data-v-13bcb571 data-v-6c6e0bff><button type="button" class="button" aria-haspopup="true" aria-expanded="false" data-v-6c6e0bff><span class="text" data-v-6c6e0bff><!----><span data-v-6c6e0bff>开源作品</span><span class="vpi-chevron-down text-icon" data-v-6c6e0bff></span></span></button><div class="menu" data-v-6c6e0bff><div class="VPMenu" data-v-6c6e0bff data-v-617b6928><div class="items" data-v-617b6928><!--[--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/works/opensource.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>个人作品</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/works/contribution.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>社区贡献</span><!--]--></a></div><!--]--><!--]--></div><!--[--><!--]--></div></div></div><!--]--><!--[--><div class="VPFlyout VPNavBarMenuGroup" data-v-13bcb571 data-v-6c6e0bff><button type="button" class="button" aria-haspopup="true" aria-expanded="false" data-v-6c6e0bff><span class="text" data-v-6c6e0bff><!----><span data-v-6c6e0bff>学习笔记</span><span class="vpi-chevron-down text-icon" data-v-6c6e0bff></span></span></button><div class="menu" data-v-6c6e0bff><div class="VPMenu" data-v-6c6e0bff data-v-617b6928><div class="items" data-v-617b6928><!--[--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/JavaScript.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>JavaScript基础</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/CSS.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>CSS基础</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/JavaScriptEnhanced.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>JavaScript进阶</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/Front-end%20Engineering.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>前端工程化</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/SSR.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>服务端渲染</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/React.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>React基础</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/React%20Hooks.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>React Hooks</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/Redux.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>Redux</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/React%20Router.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>React Router</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/MySQL.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>MySQL</span><!--]--></a></div><!--]--><!--[--><div class="VPMenuLink" data-v-617b6928 data-v-1b2f90c1><a class="VPLink link" href="/note/Rust.html" data-v-1b2f90c1><!--[--><span data-v-1b2f90c1>Rust</span><!--]--></a></div><!--]--><!--]--></div><!--[--><!--]--></div></div></div><!--]--><!--[--><a class="VPLink link VPNavBarMenuLink" href="/self/" tabindex="0" data-v-13bcb571 data-v-30b277b0><!--[--><span data-v-30b277b0>个人介绍</span><!--]--></a><!--]--><!--]--></nav><!----><div class="VPNavBarAppearance appearance" data-v-24334755 data-v-d9d5f43f><button class="VPSwitch VPSwitchAppearance" type="button" role="switch" title aria-checked="false" data-v-d9d5f43f data-v-c8a773d7 data-v-287b84a0><span class="check" data-v-287b84a0><span class="icon" data-v-287b84a0><!--[--><span class="vpi-sun sun" data-v-c8a773d7></span><span class="vpi-moon moon" data-v-c8a773d7></span><!--]--></span></span></button></div><div class="VPSocialLinks VPNavBarSocialLinks social-links" data-v-24334755 data-v-a1fa0154 data-v-a14ae2b2><!--[--><a class="VPSocialLink no-icon" href="https://github.com/ZiuChen" aria-label="github" target="_blank" rel="noopener" data-v-a14ae2b2 data-v-18957ed8><span class="vpi-social-github"></span></a><a class="VPSocialLink no-icon" href="https://juejin.cn/user/1887205216238477" aria-label target="_blank" rel="noopener" data-v-a14ae2b2 data-v-18957ed8><svg width="36" height="28" viewBox="0 0 36 28" fill="none" xmlns="http://www.w3.org/2000/svg"><path fill-rule="evenodd" clip-rule="evenodd" d="M17.5875 6.77268L21.8232 3.40505L17.5875 0.00748237L17.5837 0L13.3555 3.39757L17.5837 6.76894L17.5875 6.77268ZM17.5863 17.3955H17.59L28.5161 8.77432L25.5526 6.39453L17.59 12.6808H17.5863L17.5825 12.6845L9.61993 6.40201L6.66016 8.78181L17.5825 17.3992L17.5863 17.3955ZM17.5828 23.2891L17.5865 23.2854L32.2133 11.7456L35.1768 14.1254L28.5238 19.3752L17.5865 28L0.284376 14.3574L0 14.1291L2.95977 11.7531L17.5828 23.2891Z" fill="#1E80FF"/></svg></a><!--]--></div><div class="VPFlyout VPNavBarExtra extra" data-v-24334755 data-v-ff93ad9d data-v-6c6e0bff><button type="button" class="button" aria-haspopup="true" aria-expanded="false" aria-label="extra navigation" data-v-6c6e0bff><span class="vpi-more-horizontal icon" data-v-6c6e0bff></span></button><div class="menu" data-v-6c6e0bff><div class="VPMenu" data-v-6c6e0bff data-v-617b6928><!----><!--[--><!--[--><!----><div class="group" data-v-ff93ad9d><div class="item appearance" data-v-ff93ad9d><p class="label" data-v-ff93ad9d>Appearance</p><div class="appearance-action" data-v-ff93ad9d><button class="VPSwitch VPSwitchAppearance" type="button" role="switch" title aria-checked="false" data-v-ff93ad9d data-v-c8a773d7 data-v-287b84a0><span class="check" data-v-287b84a0><span class="icon" data-v-287b84a0><!--[--><span class="vpi-sun sun" data-v-c8a773d7></span><span class="vpi-moon moon" data-v-c8a773d7></span><!--]--></span></span></button></div></div></div><div class="group" data-v-ff93ad9d><div class="item social-links" data-v-ff93ad9d><div class="VPSocialLinks social-links-list" data-v-ff93ad9d data-v-a14ae2b2><!--[--><a class="VPSocialLink no-icon" href="https://github.com/ZiuChen" aria-label="github" target="_blank" rel="noopener" data-v-a14ae2b2 data-v-18957ed8><span class="vpi-social-github"></span></a><a class="VPSocialLink no-icon" href="https://juejin.cn/user/1887205216238477" aria-label target="_blank" rel="noopener" data-v-a14ae2b2 data-v-18957ed8><svg width="36" height="28" viewBox="0 0 36 28" fill="none" xmlns="http://www.w3.org/2000/svg"><path fill-rule="evenodd" clip-rule="evenodd" d="M17.5875 6.77268L21.8232 3.40505L17.5875 0.00748237L17.5837 0L13.3555 3.39757L17.5837 6.76894L17.5875 6.77268ZM17.5863 17.3955H17.59L28.5161 8.77432L25.5526 6.39453L17.59 12.6808H17.5863L17.5825 12.6845L9.61993 6.40201L6.66016 8.78181L17.5825 17.3992L17.5863 17.3955ZM17.5828 23.2891L17.5865 23.2854L32.2133 11.7456L35.1768 14.1254L28.5238 19.3752L17.5865 28L0.284376 14.3574L0 14.1291L2.95977 11.7531L17.5828 23.2891Z" fill="#1E80FF"/></svg></a><!--]--></div></div></div><!--]--><!--]--></div></div></div><!--[--><!--]--><button type="button" class="VPNavBarHamburger hamburger" aria-label="mobile navigation" aria-expanded="false" aria-controls="VPNavScreen" data-v-24334755 data-v-045fbadd><span class="container" data-v-045fbadd><span class="top" data-v-045fbadd></span><span class="middle" data-v-045fbadd></span><span class="bottom" data-v-045fbadd></span></span></button></div></div></div></div><div class="divider" data-v-24334755><div class="divider-line" data-v-24334755></div></div></div><!----></header><div class="VPLocalNav has-sidebar empty" data-v-dc294264 data-v-0d91adb2><div class="container" data-v-0d91adb2><button class="menu" aria-expanded="false" aria-controls="VPSidebarNav" data-v-0d91adb2><span class="vpi-align-left menu-icon" data-v-0d91adb2></span><span class="menu-text" data-v-0d91adb2>Menu</span></button><div class="VPLocalNavOutlineDropdown" style="--vp-vh:0px;" data-v-0d91adb2 data-v-a4936952><button data-v-a4936952>Return to top</button><!----></div></div></div><aside class="VPSidebar" data-v-dc294264 data-v-b298c777><div class="curtain" data-v-b298c777></div><nav class="nav" id="VPSidebarNav" aria-labelledby="sidebar-aria-label" tabindex="-1" data-v-b298c777><span class="visually-hidden" id="sidebar-aria-label" data-v-b298c777> Sidebar Navigation </span><!--[--><!--]--><!--[--><div class="no-transition group" data-v-0149f091><section class="VPSidebarItem level-0" data-v-0149f091 data-v-72633d9f><div class="item" role="button" tabindex="0" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><h2 class="text" data-v-72633d9f>我的项目</h2><!----></div><div class="items" data-v-72633d9f><!--[--><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/project/ClipboardManager/" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>超级剪贴板</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/project/Markdown/" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>超级Markdown</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/project/JSRunner/" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>超级JavaScript</p><!--]--></a><!----></div><!----></div><!--]--></div></section></div><div class="no-transition group" data-v-0149f091><section class="VPSidebarItem level-0 collapsible collapsed" data-v-0149f091 data-v-72633d9f><div class="item" role="button" tabindex="0" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><h2 class="text" data-v-72633d9f>开源作品</h2><div class="caret" role="button" aria-label="toggle section" tabindex="0" data-v-72633d9f><span class="vpi-chevron-right caret-icon" data-v-72633d9f></span></div></div><div class="items" data-v-72633d9f><!--[--><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/works/opensource.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>个人作品</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/works/contribution.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>社区贡献</p><!--]--></a><!----></div><!----></div><!--]--></div></section></div><div class="no-transition group" data-v-0149f091><section class="VPSidebarItem level-0 collapsible collapsed has-active" data-v-0149f091 data-v-72633d9f><div class="item" role="button" tabindex="0" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><h2 class="text" data-v-72633d9f>文章归档</h2><div class="caret" role="button" aria-label="toggle section" tabindex="0" data-v-72633d9f><span class="vpi-chevron-right caret-icon" data-v-72633d9f></span></div></div><div class="items" data-v-72633d9f><!--[--><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/Vue%20Demi%20%E5%81%9A%E4%BA%86%E4%BB%80%E4%B9%88%EF%BC%9F.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>Vue Demi 做了什么?</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E3%80%902023%E3%80%91%E9%9D%92%E8%AE%AD%E8%90%A5%20-%20%E5%89%8D%E7%AB%AF%E7%BB%83%E4%B9%A0%E9%A2%98%E6%B1%87%E6%80%BB%E8%A7%A3%E6%9E%90.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>【2023】青训营 - 前端练习题汇总解析</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E3%80%90%E5%AD%97%E8%8A%82%E8%B7%B3%E5%8A%A8%E3%80%91%E5%89%8D%E7%AB%AF%E9%9D%A2%E8%AF%95%E9%A2%98%E6%80%BB%E7%BB%93.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>【字节跳动】前端面试题总结</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E3%80%90%E5%BF%AB%E6%89%8B%E3%80%91%E6%B7%B1%E5%85%A5%E7%90%86%E8%A7%A3%E5%89%8D%E7%AB%AF%E9%9D%A2%E8%AF%95%E9%A2%98.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>【快手】深入理解前端面试题</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E3%80%90%E7%94%A8%E5%8F%8B%E9%87%91%E8%9E%8D%E3%80%91%E5%89%8D%E7%AB%AF%E9%9D%A2%E8%AF%95%E9%A2%98%E6%80%BB%E7%BB%93.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>【用友金融】前端面试题总结</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E4%B8%80%E6%96%87%E8%AF%BB%E6%87%82%E4%BA%8B%E4%BB%B6%E5%86%92%E6%B3%A1%E4%B8%8E%E4%BA%8B%E4%BB%B6%E6%8D%95%E8%8E%B7.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>一文读懂事件冒泡与事件捕获</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E4%B8%80%E6%96%87%E8%AF%BB%E6%87%82%E4%BC%AA%E7%B1%BB%E4%B8%8E%E4%BC%AA%E5%85%83%E7%B4%A0.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>一文读懂伪类与伪元素</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E4%B8%80%E6%96%87%E8%AF%BB%E6%87%82%E5%87%BD%E6%95%B0%E4%B8%ADthis%E6%8C%87%E5%90%91%E9%97%AE%E9%A2%98.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>一文读懂函数中this指向问题</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E4%BB%8E0%E5%AE%9E%E7%8E%B0%E4%B8%80%E4%B8%AA%E5%B9%B4%E5%BA%A6%E6%8A%A5%E5%91%8A.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>从0实现一个年度报告</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E5%BD%BB%E5%BA%95%E6%90%9E%E6%87%82%E5%AF%B9%E8%B1%A1%E7%9A%84%E6%95%B0%E6%8D%AE%E5%B1%9E%E6%80%A7%E6%8F%8F%E8%BF%B0%E7%AC%A6%E3%80%81%E5%AD%98%E5%82%A8%E5%B1%9E%E6%80%A7%E6%8F%8F%E8%BF%B0%E7%AC%A6.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>彻底搞懂对象的数据属性描述符、存储属性描述符</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E6%B5%85%E6%9E%90defineProperty%E4%B8%8EProxy%E5%AE%9E%E7%8E%B0%E7%9A%84%E5%8F%8C%E5%90%91%E7%BB%91%E5%AE%9A.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>浅析defineProperty与Proxy实现的双向绑定</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E6%B7%B1%E5%85%A5JavaScript%E6%95%B0%E6%8D%AE%E7%B1%BB%E5%9E%8B.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>深入JavaScript数据类型</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E6%B7%B1%E5%85%A5Vue3%E6%BA%90%E7%A0%81%EF%BC%8C%E7%9C%8B%E7%9C%8BVue.use%E5%90%8E%E7%A9%B6%E7%AB%9F%E5%8F%91%E7%94%9F%E4%BA%86%E4%BB%80%E4%B9%88%EF%BC%9F.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>深入Vue3源码看看Vue.use后究竟发生了什么</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E6%B7%B1%E5%85%A5%E7%90%86%E8%A7%A3Proxy%E4%B8%8EReflect.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>深入理解Proxy与Reflect</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E6%B7%B1%E5%85%A5%E7%90%86%E8%A7%A3%E6%B5%8F%E8%A7%88%E5%99%A8%E7%BC%93%E5%AD%98%E6%9C%BA%E5%88%B6.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>深入理解浏览器缓存机制</p><!--]--></a><!----></div><!----></div><div class="VPSidebarItem level-1 is-link" data-v-72633d9f data-v-72633d9f><div class="item" data-v-72633d9f><div class="indicator" data-v-72633d9f></div><a class="VPLink link link" href="/article/%E6%B7%B1%E5%85%A5%E7%90%86%E8%A7%A3%E6%B5%8F%E8%A7%88%E5%99%A8%E8%BF%90%E8%A1%8C%E5%8E%9F%E7%90%86.html" data-v-72633d9f><!--[--><p class="text" data-v-72633d9f>深入理解浏览器运行原理</p><!--]--></a><!----></div><!----></div><!--]--></div></section></div><!--]--><!--[--><!--]--></nav></aside><div class="VPContent has-sidebar" id="VPContent" data-v-dc294264 data-v-9bf49efd><div class="VPDoc has-sidebar has-aside" data-v-9bf49efd data-v-97779966><!--[--><!--]--><div class="container" data-v-97779966><div class="aside" data-v-97779966><div class="aside-curtain" data-v-97779966></div><div class="aside-container" data-v-97779966><div class="aside-content" data-v-97779966><div class="VPDocAside" data-v-97779966 data-v-c03c78a1><!--[--><!--]--><!--[--><!--]--><nav aria-labelledby="doc-outline-aria-label" class="VPDocAsideOutline" data-v-c03c78a1 data-v-951eb1c9><div class="content" data-v-951eb1c9><div class="outline-marker" data-v-951eb1c9></div><div aria-level="2" class="outline-title" id="doc-outline-aria-label" role="heading" data-v-951eb1c9>On this page</div><ul class="VPDocOutlineItem root" data-v-951eb1c9 data-v-317754ad><!--[--><!--]--></ul></div></nav><!--[--><!--]--><div class="spacer" data-v-c03c78a1></div><!--[--><!--]--><!----><!--[--><!--]--><!--[--><!--]--></div></div></div></div><div class="content" data-v-97779966><div class="content-container" data-v-97779966><!--[--><!--]--><main class="main" data-v-97779966><div style="position:relative;" class="vp-doc _article_%E5%BD%BB%E5%BA%95%E6%90%9E%E6%87%82%E5%AF%B9%E8%B1%A1%E7%9A%84%E6%95%B0%E6%8D%AE%E5%B1%9E%E6%80%A7%E6%8F%8F%E8%BF%B0%E7%AC%A6%E3%80%81%E5%AD%98%E5%82%A8%E5%B1%9E%E6%80%A7%E6%8F%8F%E8%BF%B0%E7%AC%A6" data-v-97779966><div><h1 id="彻底搞懂对象的数据属性描述符、存储属性描述符" tabindex="-1">彻底搞懂对象的数据属性描述符、存储属性描述符 <a class="header-anchor" href="#彻底搞懂对象的数据属性描述符、存储属性描述符" aria-label="Permalink to &quot;彻底搞懂对象的数据属性描述符、存储属性描述符&quot;"></a></h1><h2 id="属性描述符" tabindex="-1">属性描述符 <a class="header-anchor" href="#属性描述符" aria-label="Permalink to &quot;属性描述符&quot;"></a></h2><div class="language-js vp-adaptive-theme"><button title="Copy Code" class="copy"></button><span class="lang">js</span><pre class="shiki shiki-themes github-light github-dark vp-code" tabindex="0"><code><span class="line"><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> let</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> name: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;ziu&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> age: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">18</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> Object.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">defineProperty</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj, </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;height&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> value: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">1.88</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> })</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj) </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// { name: &#39;ziu&#39;, age: 18 }</span></span></code></pre></div><p><code>obj</code>对象的控制台输出中,并没有<code>defineProperty</code>新定义的<code>height</code>,这是因为不可枚举的(不可遍历的),在打印时并没有和其他属性一起输出。这个属性已经被添加到对象中,只不过不可见。</p><div class="language-js vp-adaptive-theme"><button title="Copy Code" class="copy"></button><span class="lang">js</span><pre class="shiki shiki-themes github-light github-dark vp-code" tabindex="0"><code><span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj.height) </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// 1.88</span></span></code></pre></div><p>属性描述符是一个对象,根据功能不同,可以分为两类:<strong>数据属性描述符</strong><strong>存储属性描述符</strong></p><h3 id="数据属性描述符" tabindex="-1">数据属性描述符 <a class="header-anchor" href="#数据属性描述符" aria-label="Permalink to &quot;数据属性描述符&quot;"></a></h3><ul><li>数据属性描述符Data Properties <ul><li><code>value</code>该属性对应的值,默认<code>undefined</code></li><li><code>configurable</code>该属性描述符是否可被改变、是否可被删除,默认为<code>false</code></li><li><code>enumerable</code>该属性是否可被枚举,默认为<code>false</code></li><li><code>writable</code>该属性是否可以被写入新的值,默认为<code>false</code></li></ul></li></ul><p><strong>没有用属性描述符定义的对象属性(直接使用<code>.</code>语法)</strong>,也是具有以上属性描述符的特性的,<code>value</code>值为属性被赋值的值,其他<code>configurable</code><code>emumerable</code><code>writable</code>默认值都为<code>true</code><strong>注意,属性描述符区全为小写。</strong></p><div class="language-js vp-adaptive-theme"><button title="Copy Code" class="copy"></button><span class="lang">js</span><pre class="shiki shiki-themes github-light github-dark vp-code" tabindex="0"><code><span class="line"><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> let</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> name: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;ziu&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> age: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">18</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span class="line"><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // 数据属性描述符</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> Object.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">defineProperty</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj, </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;address&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> value: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;Beijing&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// 该属性对应的值默认为undefine</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> configurable: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">false</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// 该属性描述符是否可被改变、是否可被删除默认为false</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> enumerable: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">true</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// 该属性是否可被枚举默认为false</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> writable: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">true</span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // 该属性是否可以被写入新的值默认为false</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> })</span></span>
<span class="line"><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // configurable</span></span>
<span class="line"><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> delete</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj.address</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj.address </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> &quot;Shanghai&quot;</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj.address) </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// Beijing</span></span>
<span class="line"><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // enumerable</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj)</span></span>
<span class="line"><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> for</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">let</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> key </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">in</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj) {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(key)</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(Object.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">keys</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj))</span></span>
<span class="line"><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // writable</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj.address </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> &quot;Tianjin&quot;</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj.address)</span></span></code></pre></div><h3 id="存储属性描述符" tabindex="-1">存储属性描述符 <a class="header-anchor" href="#存储属性描述符" aria-label="Permalink to &quot;存储属性描述符&quot;"></a></h3><ul><li>存储属性描述符Accessor Properties <ul><li><code>get</code>当访问该属性时,会调用此函数,默认为<code>undefined</code></li><li><code>set</code>当属性值被修改时,会调用此函数,默认为<code>undefined</code></li></ul></li></ul><p>注意,<code>get</code><code>set</code>描述符与<code>vaule</code><code>writable</code>描述符不共存。</p><table tabindex="0"><thead><tr><th></th><th><code>configurable</code></th><th><code>enumerable</code></th><th><code>value</code></th><th><code>writable</code></th><th><code>get</code></th><th><code>set</code></th></tr></thead><tbody><tr><td>数据描述符</td><td>可以</td><td>可以</td><td>可以</td><td>可以</td><td><strong>不可以</strong></td><td><strong>不可以</strong></td></tr><tr><td>存取描述符</td><td>可以</td><td>可以</td><td><strong>不可以</strong></td><td><strong>不可以</strong></td><td>可以</td><td>可以</td></tr></tbody></table><div class="language-js vp-adaptive-theme"><button title="Copy Code" class="copy"></button><span class="lang">js</span><pre class="shiki shiki-themes github-light github-dark vp-code" tabindex="0"><code><span class="line"><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> let</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> name: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;ziu&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> age: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">18</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> _address: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;Beijing&quot;</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span class="line"><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // Accessor Properties</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> Object.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">defineProperty</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj, </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;address&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> enumerable: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">true</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> configurable: </span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">true</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span class="line"><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // value: &quot;Beijing&quot;,</span></span>
<span class="line"><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // writable: true,</span></span>
<span class="line"><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> get</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">function</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">() {</span></span>
<span class="line"><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> return</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> this</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">._address</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> },</span></span>
<span class="line"><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> set</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">function</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">val</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">) {</span></span>
<span class="line"><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> this</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">._address </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> val</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> })</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj.address) </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// 调用getter() Beijing</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj.address </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> &quot;Shanghai&quot;</span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // 调用setter()</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj._address) </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// Shanghai</span></span></code></pre></div><h3 id="应用场景" tabindex="-1">应用场景 <a class="header-anchor" href="#应用场景" aria-label="Permalink to &quot;应用场景&quot;"></a></h3><ol><li>隐藏某个私有属性,希望直接被外界使用和赋值。(下划线开头的变量一般为私有属性)</li><li>获取某个属性被访问或赋值的时刻,可以设置伴随被访问或被赋值时,执行其他函数。</li></ol><div class="language-js vp-adaptive-theme"><button title="Copy Code" class="copy"></button><span class="lang">js</span><pre class="shiki shiki-themes github-light github-dark vp-code" tabindex="0"><code><span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> Object.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">defineProperty</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj, </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;address&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">, {</span></span>
<span class="line"><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> get</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">function</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">() {</span></span>
<span class="line"><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> bar</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">()</span></span>
<span class="line"><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> return</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> this</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">._address</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> },</span></span>
<span class="line"><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> set</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">function</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#E36209;--shiki-dark:#FFAB70;">val</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">) {</span></span>
<span class="line"><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> foo</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">()</span></span>
<span class="line"><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> this</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">._address </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> val</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> })</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(obj.address) </span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;">// got address value once</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> obj.address </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">=</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;"> &quot;Shanghai&quot;</span><span style="--shiki-light:#6A737D;--shiki-dark:#6A737D;"> // resetted address value once</span></span>
<span class="line"><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> function</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> bar</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">() {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;got address value once&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">)</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span>
<span class="line"><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;"> function</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> foo</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">() {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> console.</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;">log</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;resetted address value once&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">)</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> }</span></span></code></pre></div></div></div></main><footer class="VPDocFooter" data-v-97779966 data-v-00e73594><!--[--><!--]--><div class="edit-info" data-v-00e73594><div class="edit-link" data-v-00e73594><a class="VPLink link vp-external-link-icon no-icon edit-link-button" href="https://github.com/ZiuChen/ZiuChen.github.io/edit/main/docs/article/彻底搞懂对象的数据属性描述符、存储属性描述符.md" target="_blank" rel="noreferrer" data-v-00e73594><!--[--><span class="vpi-square-pen edit-link-icon" data-v-00e73594></span> Edit this page on GitHub<!--]--></a></div><div class="last-updated" data-v-00e73594><p class="VPLastUpdated" data-v-00e73594 data-v-9c9bd9f9>Updated Date: <time datetime="2024-11-22T14:57:15.000Z" data-v-9c9bd9f9></time></p></div></div><nav class="prev-next" aria-labelledby="doc-footer-aria-label" data-v-00e73594><span class="visually-hidden" id="doc-footer-aria-label" data-v-00e73594>Pager</span><div class="pager" data-v-00e73594><a class="VPLink link pager-link prev" href="/article/%E4%BB%8E0%E5%AE%9E%E7%8E%B0%E4%B8%80%E4%B8%AA%E5%B9%B4%E5%BA%A6%E6%8A%A5%E5%91%8A.html" data-v-00e73594><!--[--><span class="desc" data-v-00e73594>Previous page</span><span class="title" data-v-00e73594>从0实现一个年度报告</span><!--]--></a></div><div class="pager" data-v-00e73594><a class="VPLink link pager-link next" href="/article/%E6%B5%85%E6%9E%90defineProperty%E4%B8%8EProxy%E5%AE%9E%E7%8E%B0%E7%9A%84%E5%8F%8C%E5%90%91%E7%BB%91%E5%AE%9A.html" data-v-00e73594><!--[--><span class="desc" data-v-00e73594>Next page</span><span class="title" data-v-00e73594>浅析defineProperty与Proxy实现的双向绑定</span><!--]--></a></div></nav></footer><!--[--><!--]--></div></div></div><!--[--><!--]--></div></div><footer class="VPFooter has-sidebar" data-v-dc294264 data-v-fce9f0d0><div class="container" data-v-fce9f0d0><p class="message" data-v-fce9f0d0>Released under the MIT License.</p><p class="copyright" data-v-fce9f0d0>Copyright © 2022-PRESENT ZiuChen</p></div></footer><!--[--><!--]--></div></div>
<script>window.__VP_HASH_MAP__=JSON.parse("{\"article_vue demi 做了什么?.md\":\"BhZSqQSm\",\"article_【2023】青训营 - 前端练习题汇总解析.md\":\"Bc4Ypeoe\",\"article_【字节跳动】前端面试题总结.md\":\"BGDyqyeI\",\"article_【快手】深入理解前端面试题.md\":\"uNCeedvK\",\"article_【用友金融】前端面试题总结.md\":\"B0gpbAVR\",\"article_一文读懂事件冒泡与事件捕获.md\":\"B47z35Iv\",\"article_一文读懂伪类与伪元素.md\":\"DT7lzD40\",\"article_一文读懂函数中this指向问题.md\":\"Dd6INNo2\",\"article_从0实现一个年度报告.md\":\"BUBLtBr5\",\"article_彻底搞懂对象的数据属性描述符、存储属性描述符.md\":\"BOJlLhrD\",\"article_浅析defineproperty与proxy实现的双向绑定.md\":\"B-n-NCKA\",\"article_深入javascript数据类型.md\":\"C4q-35GU\",\"article_深入vue3源码看看vue.use后究竟发生了什么.md\":\"KGFyhPCJ\",\"article_深入理解proxy与reflect.md\":\"DR-w6UTt\",\"article_深入理解浏览器缓存机制.md\":\"BBHKnc3F\",\"article_深入理解浏览器运行原理.md\":\"CnB0AyMB\",\"demos_promiseify-post-message_index.md\":\"PG7uvfY5\",\"demos_promiseify-post-message_inner.md\":\"CG70cVVN\",\"index.md\":\"cTPC60fJ\",\"note_css.md\":\"CbV6FIKh\",\"note_front-end engineering.md\":\"CJJ0TG4f\",\"note_javascript.md\":\"xwn8B2B4\",\"note_javascriptenhanced.md\":\"GuVCxDms\",\"note_mysql.md\":\"j7C5bSXX\",\"note_react hooks.md\":\"COaoTn1V\",\"note_react router.md\":\"CeuXGtED\",\"note_react.md\":\"CByZfZES\",\"note_redux.md\":\"DTHw7BH5\",\"note_rust.md\":\"19N76PIW\",\"note_ssr.md\":\"DRfviiVG\",\"project_clipboardmanager_guide_index.md\":\"DGQByktO\",\"project_clipboardmanager_index.md\":\"1LHRNolY\",\"project_clipboardmanager_log_index.md\":\"CAfAnxns\",\"project_clipboardmanager_statement_index.md\":\"Cb7Xnci7\",\"project_jsrunner_index.md\":\"Ws5eXb9s\",\"project_jsrunner_log_index.md\":\"DsD0rNk8\",\"project_markdown_index.md\":\"DwN50MJw\",\"project_markdown_log_index.md\":\"BKBXys8Q\",\"project_markdown_shortcut_index.md\":\"BTsZDy-C\",\"self_index.md\":\"CxtJ8GDf\",\"works_contribution.md\":\"CWU_6gLZ\",\"works_opensource.md\":\"D02w8SSg\"}");window.__VP_SITE_DATA__=JSON.parse("{\"lang\":\"en-US\",\"dir\":\"ltr\",\"title\":\"ZiuChen\",\"description\":\"Unlimited Progress.\",\"base\":\"/\",\"head\":[],\"router\":{\"prefetchLinks\":true},\"appearance\":true,\"themeConfig\":{\"logo\":\"/logo.png\",\"nav\":[{\"text\":\"首页\",\"link\":\"/\"},{\"text\":\"我的项目\",\"items\":[{\"text\":\"超级剪贴板\",\"link\":\"/project/ClipboardManager/\"},{\"text\":\"超级Markdown\",\"link\":\"/project/Markdown/\"},{\"text\":\"超级JavaScript\",\"link\":\"/project/JSRunner/\"}]},{\"text\":\"开源作品\",\"items\":[{\"text\":\"个人作品\",\"link\":\"/works/opensource\"},{\"text\":\"社区贡献\",\"link\":\"/works/contribution\"}]},{\"text\":\"学习笔记\",\"items\":[{\"text\":\"JavaScript基础\",\"link\":\"/note/JavaScript\"},{\"text\":\"CSS基础\",\"link\":\"/note/CSS\"},{\"text\":\"JavaScript进阶\",\"link\":\"/note/JavaScriptEnhanced\"},{\"text\":\"前端工程化\",\"link\":\"/note/Front-end Engineering\"},{\"text\":\"服务端渲染\",\"link\":\"/note/SSR\"},{\"text\":\"React基础\",\"link\":\"/note/React\"},{\"text\":\"React Hooks\",\"link\":\"/note/React Hooks\"},{\"text\":\"Redux\",\"link\":\"/note/Redux\"},{\"text\":\"React Router\",\"link\":\"/note/React Router\"},{\"text\":\"MySQL\",\"link\":\"/note/MySQL\"},{\"text\":\"Rust\",\"link\":\"/note/Rust\"}]},{\"text\":\"个人介绍\",\"link\":\"/self/\"}],\"sidebar\":[{\"text\":\"我的项目\",\"items\":[{\"text\":\"超级剪贴板\",\"link\":\"/project/ClipboardManager/\"},{\"text\":\"超级Markdown\",\"link\":\"/project/Markdown/\"},{\"text\":\"超级JavaScript\",\"link\":\"/project/JSRunner/\"}]},{\"text\":\"开源作品\",\"collapsed\":true,\"items\":[{\"text\":\"个人作品\",\"link\":\"/works/opensource\"},{\"text\":\"社区贡献\",\"link\":\"/works/contribution\"}]},{\"text\":\"文章归档\",\"collapsed\":true,\"items\":[{\"text\":\"Vue Demi 做了什么?\",\"link\":\"/article/Vue Demi 做了什么?.md\"},{\"text\":\"【2023】青训营 - 前端练习题汇总解析\",\"link\":\"/article/【2023】青训营 - 前端练习题汇总解析.md\"},{\"text\":\"【字节跳动】前端面试题总结\",\"link\":\"/article/【字节跳动】前端面试题总结.md\"},{\"text\":\"【快手】深入理解前端面试题\",\"link\":\"/article/【快手】深入理解前端面试题.md\"},{\"text\":\"【用友金融】前端面试题总结\",\"link\":\"/article/【用友金融】前端面试题总结.md\"},{\"text\":\"一文读懂事件冒泡与事件捕获\",\"link\":\"/article/一文读懂事件冒泡与事件捕获.md\"},{\"text\":\"一文读懂伪类与伪元素\",\"link\":\"/article/一文读懂伪类与伪元素.md\"},{\"text\":\"一文读懂函数中this指向问题\",\"link\":\"/article/一文读懂函数中this指向问题.md\"},{\"text\":\"从0实现一个年度报告\",\"link\":\"/article/从0实现一个年度报告.md\"},{\"text\":\"彻底搞懂对象的数据属性描述符、存储属性描述符\",\"link\":\"/article/彻底搞懂对象的数据属性描述符、存储属性描述符.md\"},{\"text\":\"浅析defineProperty与Proxy实现的双向绑定\",\"link\":\"/article/浅析defineProperty与Proxy实现的双向绑定.md\"},{\"text\":\"深入JavaScript数据类型\",\"link\":\"/article/深入JavaScript数据类型.md\"},{\"text\":\"深入Vue3源码看看Vue.use后究竟发生了什么\",\"link\":\"/article/深入Vue3源码看看Vue.use后究竟发生了什么.md\"},{\"text\":\"深入理解Proxy与Reflect\",\"link\":\"/article/深入理解Proxy与Reflect.md\"},{\"text\":\"深入理解浏览器缓存机制\",\"link\":\"/article/深入理解浏览器缓存机制.md\"},{\"text\":\"深入理解浏览器运行原理\",\"link\":\"/article/深入理解浏览器运行原理.md\"}]}],\"socialLinks\":[{\"icon\":\"github\",\"link\":\"https://github.com/ZiuChen\"},{\"icon\":{\"svg\":\"<svg width=\\\"36\\\" height=\\\"28\\\" viewBox=\\\"0 0 36 28\\\" fill=\\\"none\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path fill-rule=\\\"evenodd\\\" clip-rule=\\\"evenodd\\\" d=\\\"M17.5875 6.77268L21.8232 3.40505L17.5875 0.00748237L17.5837 0L13.3555 3.39757L17.5837 6.76894L17.5875 6.77268ZM17.5863 17.3955H17.59L28.5161 8.77432L25.5526 6.39453L17.59 12.6808H17.5863L17.5825 12.6845L9.61993 6.40201L6.66016 8.78181L17.5825 17.3992L17.5863 17.3955ZM17.5828 23.2891L17.5865 23.2854L32.2133 11.7456L35.1768 14.1254L28.5238 19.3752L17.5865 28L0.284376 14.3574L0 14.1291L2.95977 11.7531L17.5828 23.2891Z\\\" fill=\\\"#1E80FF\\\"/></svg>\"},\"link\":\"https://juejin.cn/user/1887205216238477\"}],\"editLink\":{\"pattern\":\"https://github.com/ZiuChen/ZiuChen.github.io/edit/main/docs/:path\",\"text\":\"Edit this page on GitHub\"},\"footer\":{\"message\":\"Released under the MIT License.\",\"copyright\":\"Copyright © 2022-PRESENT ZiuChen\"},\"lastUpdatedText\":\"Updated Date\",\"search\":{\"provider\":\"algolia\",\"options\":{\"appId\":\"LFZ2CPWWUG\",\"apiKey\":\"b4fd296ea5e467b3ac4a582160ff3122\",\"indexName\":\"ziuchenio\"}}},\"locales\":{},\"scrollOffset\":134,\"cleanUrls\":false}");</script>
</body>
</html>