瞭解JavaScript 對象屬性的標簽

来源:http://www.cnblogs.com/JianweiWang/archive/2016/02/27/5221060.html
-Advertisement-
Play Games

對象屬性的標簽 value(屬性值), writable(屬性可寫), enumerable(屬性可枚舉), configurable(屬性可配置), 這些屬性標簽使對象所持有的屬性體現出不同的特性, 以便開發者開發使用. value value, 屬性的值, 這個屬性是最直觀的體現, 一個屬性我們


  對象屬性的標簽

  value(屬性值), writable(屬性可寫), enumerable(屬性可枚舉), configurable(屬性可配置), 這些屬性標簽使對象所持有的屬性體現出不同的特性, 以便開發者開發使用.

  value

  value, 屬性的值, 這個屬性是最直觀的體現, 一個屬性我們使用的就是它的值, 這個值的類型可以是對象, 字元串, 值等任意類型. 如果未設置的話, 值會是undefined.

  Object.defineProperty(person, 'name', {

    configurable : false,

    writable : false,

    enumerable : true,

    value : "Jianwei Wang"

  });

  document.write(person.name);  //Jianwei Wang

  "Jianwei Wang"就是person.name的值.

  configurable

  confirurable, 顧名思義可配置的, 意思就是在標簽為true時這個屬性允許修改各種屬性標簽配置(true or false), delete關鍵字是否可以刪除這個屬性, 如果標簽為false, 那麼是不允許修改標簽配置的, delete也不可以使用了. 它的作用主要是配置屬性的標簽.

  writable

  writable, 可寫入的, 如果這個設置為false, 那麼這個屬性將不允許寫入, 也就無法將writable設置為新的值.  

  代碼演示, 可寫與可配置的特性.

 1 <!DOCTYPE HTML>
 2 <html> 
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 5 <title></title>
 6 </head>
 7 <body>
 8 <script type="text/javascript">
 9  //聲明一個對象並初始化
10 var person = {
11     name : "wang",
12     age : 23
13 }; 
14 //定義一個key為hobby的屬性, 設置為不可配置, 值為eat.
15 //未設置的標簽值預設為false, 所以這個屬性是不允許配置, 枚舉, 以及寫入的.
16 Object.defineProperty(person, 'hobby', {
17     value : "eat"
18 });
19 person.hobby = "run";   //寫入屬性為run
20 document.write(person.hobby);   //eat, 說明寫入失敗
21 Object.defineProperty(person, 'hobby', {
22     writable : true
23 }); //對屬性進行重新配置, 發現出錯, 不允許重新配置可寫入.
24 </script>
25 </body>
26 </html>

  enumerable

  enumerable, 可枚舉的, 如果將其關閉, 那麼這個屬性將不會被遍歷出來. 所以那些用於屬性遍歷的方法就都不是很好用了(for in, Object.keys等), 檢測還是可以的(in, hasOwnProperty等). 所以總結起來就是enumerable關閉後的作用就是, 讓你知道我有, 但是就是不給你看.

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=gb18030">
 5 <title></title>
 6 <script type="text/javascript">
 7     var person = {
 8         name : "Jianwei Wang",
 9         age : 23
10     };  //聲明並初始化對象
11     Object.defineProperty(person, "gender", {
12         configurable : true,
13         enumerable : true,
14         value : "male"
15     }); //配置一個新的屬性gender, 設置為可配置, 可枚舉的, 值為male
16     document.write(Object.keys(person) + "<br />"); //name, age, gender
17     Object.defineProperty(person, "gender", {
18         enumerable : false,
19     }); //重新配置gender為不可枚舉屬性.
20     document.write(Object.keys(person) + "<br />"); //name, age
21     document.write("gender" in person); //true
22 </script>
23 </head>
24 <body>
25 </body>
26 </html>

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我們用抽象構建框架,用實現擴展細節的註意事項而已:單一職責原則告訴我們實現類要職責單一;里氏替換原則告訴我們不要破壞繼承體系;依賴倒置原則告訴我們要面向介面編程;介面隔離原則告訴我們在設計介面的時候要精簡單一;迪米特法則告訴我們要降低耦合。而開閉原則是總綱,他告訴我們要對擴展開放,對修改關閉。
  • 重要程度:★★★☆☆ 一、什麼是模板方法模式 使用了JAVA的繼承機制,在抽象類中定義一個模板方法,該方法引用了若幹個抽象方法(由子類實現)或具體方法(子類可以覆蓋重寫); 二、補充說明 其實就是JAVA的繼承以及抽象方法、重寫覆蓋的使用; 一般把模板方法定義成final避免被子類修改 三、角色 抽
  • 定義:一個對象應該對其他對象保持最少的瞭解。 問題由來:類與類之間的關係越密切,耦合度越大,當一個類發生改變時,對另一個類的影響也越大。 解決方案:儘量降低類與類之間的耦合。
  • 重要程度:★★★☆☆ 一、什麼是責任鏈模式 為請求創建了一個接收者對象的鏈,每個接收者都包含對另一個接收者的引用,當某個接受者不能處理該請求時,會將該請求轉給下一個接受者處理; 二、補充說明 請求發送者與請求接受者解耦 應用例子:struts的攔截器,servlet的過濾器 三、角色 抽象請求處理者
  • •低層模塊儘量都要有抽象類或介面,或者兩者都有。 •變數的聲明類型儘量是抽象類或介面。 •使用繼承時遵循里氏替換原則。
  • 在CSS網頁開發佈局中,需要對浮動和定位有深刻的理解才能在開發中游刃有餘。基於此,在博客園中做了本篇總結,這些總結來自實踐經驗和閱讀一些書籍後的理解總結。主要內容為浮動,清除浮動,定位。
  • 編者註:作者以一個運動的小車為例子,講述了三種實現HTML5動畫的方式,思路清晰,動畫不僅僅是canvas,還有css3和javascript.通過合理的選擇,來實現最優的實現。 PS:由於顯卡、錄製的幀間隔,以及可能你電腦處理器的原因,播放過程可能有些不太流暢或者失真! 分三種方式實現: (1)
  • 項目中需要一個下載功能,根據系統跳轉到不同的頁面,如iphone跳轉到IOS頁面,android跳轉到android頁面。 下麵為頁面判斷頁面: <!DOCTYPE HTML> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>手機AP
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...