JavaScript 对象属性

属性是任何JavaScript对象最重要的部分

JavaScript 属性

属性指的是与 JavaScript 对象相关的值。JavaScript 对象是无序属性的集合。属性通常可以被修改、添加和删除,但是某些属性是只读的。

访问 JavaScript 属性

访问对象属性的语法是:

复制代码
objectName.property           // person.age

或者:

复制代码
objectName["property"]       // person["age"]

或者:

复制代码
objectName[expression]       // x = "age"; person[x]

表达式必须计算为属性名。

例子 1

复制代码
<!DOCTYPE html>
<html lang="en">

<body>
    <p id="demo"></p>
    <script>
        var person = {
            firstname: "Rose",
            lastname: "li",
            age: 20,
            color: "pick"
        };
        document.getElementById("demo").innerHTML = person.firstname + " is " + person.age + " years old.";
    </script>
</body>

</html>
//Rose is 20 years old.

例子 2

复制代码
<!DOCTYPE html>
<html>

<body>

    <p id="demo"></p>

    <script>
        var person = {
            firstname: "Rose",
            lastname: "li",
            age: 20,
            color: "pick"
        };

        document.getElementById("demo").innerHTML = person["firstname"] + " is " + person["age"] + " years old.";
    </script>

</body>

</html>
//Rose is 20 years old.

JavaScript for...in 循环

JavaScript for...in 语句遍历对象的属性

复制代码
for (variable in object) {
    要执行的代码
}

for...in 循环中的代码块会为每个属性执行一次

复制代码
<!DOCTYPE html>
<html>

<body>

    <p id="demo"></p>

    <script>
        var txt = "";
        var person = { fname: "Rose", lname: "Li", age: 20 };
        var x;
        for (x in person) {
            txt += person[x] + " ";
        }

        document.getElementById("demo").innerHTML = txt;
    </script>

</body>

</html>
//Rose Li 20

添加新属性

您可以通过简单的赋值,向已存在的对象添加新属性。

假设 person 对象已存在 - 那么您可以为其添加新属性:

实例

复制代码
<!DOCTYPE html>
<html>

<body>

    <p id="demo"></p>

    <script>
        var person = {
            firstName: "Rose",
            lastName: "Li",
            age: 20,
            color: "blue"
        }
        person.nationality = "China";
        document.getElementById("demo").innerHTML = person.firstName + " is " + person.nationality + " .";
    </script>

</body>

</html>
//Rose is China .

删除属性

delete 关键词从对象中删除属性

复制代码
<!DOCTYPE html>
<html lang="en">
<body>
    <p id="demo"></p>
    <script>
        var person={
            frirstname:"Rose",
            lastname:"Tina",
            age:20,
            color:"blue"
        }
        delete person.age;
        document.getElementById("demo").innerHTML=
        person.frirstname+" is "+person.age+" years old";
    </script>

</body>
</html>
//Rose is undefined years old

delete关键词会同时删除属性得值和属性本身

删除完成后,属性在呗添加回来之前是无法使用的

delete操作符被设计用于对象属性,它对变量或函数没有影响。

delete操作符不应被用于预定义的JavaScript对象属性。这样做会使应用程序崩溃

属性值

所有属性都有名称。此外它们还有值。值是属性的特性之一。

其他特性包括:可列举、可配置、可写。

这些特性定义了属性被访问的方式(是可读的还是可写的?)

在 JavaScript 中,所有属性都是可读的,但是只有值是可修改的(只有当属性为可写时)。

(ECMAScript 5 拥有获取和设置所有属性特性的方法)

原型属性

JavaScript对象继承了他们的原型的属性

delete关键词不会删除被继承的属性,但是如果您删除了某个原型属性,则将影响到所有从原型继承的对象

相关推荐
SKYDROID云卓小助手22 分钟前
无人设备遥控器之差分信号抗干扰技术
网络·stm32·单片机·嵌入式硬件·算法
YJlio1 小时前
ListDLLs & Handle 学习笔记(8.11):谁注入了 DLL?谁占着文件不放?一篇教你全搞定
网络·笔记·学习
不爱吃糖的程序媛1 小时前
Electron 智能文件分析器开发实战适配鸿蒙
前端·javascript·electron
风车带走过往2 小时前
Windows10 使用 dynv6 + ddns-go 实现 IPv6 固定域名远程访问指南
网络
flashlight_hi2 小时前
LeetCode 分类刷题:3217. 从链表中移除在数组中存在的节点
javascript·数据结构·leetcode·链表
爱奥尼欧2 小时前
【Linux笔记】网络部分——NAT-代理-网络穿透
linux·网络·笔记
Java追光着2 小时前
React Native 自建 JS Bundle OTA 更新系统:从零到一的完整实现与踩坑记录
javascript·react native·react.js
努力往上爬de蜗牛2 小时前
react native 运行问题和调试 --持续更新
javascript·react native·react.js
njxiejing2 小时前
基于Packet Tracer的路由器的基本配置(地址、密码,远程登录)
网络·智能路由器
阿巴~阿巴~3 小时前
UDP服务端绑定INADDR_ANY后,客户端该用什么IP访问?
服务器·网络·udp协议·网络测试·udp套接字编程·inaddr_any