代码世界的构建有一个不可或缺的支柱(如何让代码更加稳健)

2024-02-22 21:04

本文主要是介绍代码世界的构建有一个不可或缺的支柱(如何让代码更加稳健),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一.概念引入

二.属性描述符的常见用法

三.实例运用(数据验证)

三.基于JS的属性描述符

使用中常见的问题


最近学JavaScript的过程中,有幸学到了一个新的知识点----属性描述符,尽管它在业务代码中可能并不常见,但是许多库源码中都有它的身影,比如vue

一.概念引入

属性描述符可以理解为用于描述数据对象属性的一种标识符或标签。它可以用来描述数据的特征、性质或其他相关信息。例如,在编程中,我们可以为一个对象定义一系列属性,每个属性都有一个相应的属性描述符,用于说明该属性的名称、数据类型、是否可读/可写等。
 
属性描述符的作用是提供对对象属性的更详细的描述和控制。它们可以用于数据建模、数据验证、访问控制等方面。通过使用属性描述符,我们可以更好地组织和管理数据,确保数据的一致性和正确性。
 
在不同的编程语言或领域中,属性描述符的具体实现和用法可能会有所不同。有些语言可能提供了特定的语法或机制来定义和使用属性描述符,而在其他情况下,可能需要通过自定义类或数据结构来实现类似的功能。

二.属性描述符的常见用法

在编程中,属性描述符有很多常见的用法,以下是一些常见的例子:
 
- 数据验证:通过定义属性描述符,可以在设置或修改属性值时进行数据验证,确保属性的值符合一定的规则或约束。
- 访问控制:可以使用属性描述符来控制属性的可读/可写性,例如限制某些属性只能被读取,或者只允许在特定条件下进行修改。
- 自动计算或修改属性值:属性描述符可以在属性被访问或修改时执行一些自动的计算或修改操作,例如根据其他属性的值来计算某个属性的值
- 数据序列化和反序列化:在对象序列化和反序列化过程中,属性描述符可以用于指定如何将属性值转换为特定的格式(如 JSON、XML 等),以及在反序列化时将数据还原为对象的属性。
- 属性观察者或通知机制:通过属性描述符,可以注册观察者或回调函数,当属性发生变化时触发相应的操作,例如通知其他部分的代码进行更新。
- 缓存和性能优化:利用属性描述符,可以实现属性的缓存机制,避免不必要的计算或数据获取,提高程序的性能。
 
这些只是属性描述符的一些常见用法,具体的应用场景和用法取决于编程语言和项目的需求。不同的编程语言可能有不同的实现方式和特性来支持属性描述符的使用。
 
例如,在 Python 中,可以使用  @property  装饰器和  @descriptor  类装饰器来定义属性描述符。通过定义特定的方法(如  getter 、 setter 、 deleter  等)来控制属性的访问和修改行为。
 

三.实例运用(数据验证)

1. 整数范围验证:假设我们有一个表示年龄的属性,可以使用属性描述符来确保年龄值在合理的范围内(例如 18 到 120 岁之间)。

class Person:@propertydef age(self):return self._age@age.setterdef age(self, value):if not 18 <= value <= 120:raise ValueError("年龄必须在 18 到 120 岁之间。")self._age = value


在这个例子中, age  属性的  setter  方法会检查新设置的年龄值是否在指定范围内,如果不在范围内,会抛出一个异常。


2. 字符串格式验证:如果有一个表示电子邮件地址的属性,可以使用属性描述符来验证电子邮件地址的格式是否正确。

class Person:@propertydef email(self):return self._email@email.setterdef email(self, value):if not re.match(r"^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+\.[a-zA-Z0-9-.]+$", value):raise ValueError("无效的电子邮件地址。")self._email = value


在这个例子中,使用了正则表达式来验证电子邮件地址的格式是否正确。


3. 数据类型验证:可以使用属性描述符来确保属性的值是特定的数据类型,例如整数或浮点数。 

class Person:@propertydef score(self):return self._score@score.setterdef score(self, value):if not isinstance(value, (int, float)):raise TypeError("分数必须是整数或浮点数。")self._score = value


在这个例子中, score  属性的  setter  方法会检查新设置的分数值是否为整数或浮点数类型。
这些只是一些简单的数据验证示例,实际应用中可以根据具体的需求和数据验证规则来设计更复杂的属性描述符。通过在属性的  setter  方法中进行验证,可以确保数据的一致性和正确性,避免无效或不合法的数据进入对象。

三.基于JS的属性描述符

在 JavaScript 中,属性描述符用于描述和定义对象属性的特性。属性描述符是一个内部对象,包含以下常见属性:
 
- Configurable:决定是否可以使用  delete  删除属性,以及是否可以修改属性描述符的特性,默认值为  true 。
- Enumerable:决定属性是否出现在对象的属性枚举中,比如是否可以通过  for-in  循环返回该属性,默认值为  true 。
- Writable:决定是否可以修改属性的值,默认值为  true 。
- Value:包含这个属性的数据值,读取属性值的时候,从这个位置读;写入属性值的时候,把新值保存在这个位置。默认值为  undefined 。
- Getter:在读取属性时调用的函数。默认值为  undefined 。
- Setter:在写入属性时调用的函数。默认值为  undefined 。
 ps:getter和setter常常放在一起,合称访问器
如果属性同时具有  getter  和  setter  方法,那么它是一个读/写属性;如果它只有  getter  方法,那么它是一个只读属性;如果它只有  setter  方法,那么它是一个只写属性;读取只写属性总是返回  undefined 。
 
以下是一个使用属性描述符定义可读/写属性的示例:
 

var obj = {};
Object.defineProperty(obj, 'x', {configurable: true,enumerable: true,writable: true,value: 0,getter: function() {return this._x;},setter: function(val) {if (typeof val !== 'number') {throw new TypeError('Invalid value');}this._x = val;}
});console.log(obj.x); obj.x = 5;console.log(obj.x);


在这个示例中,通过  Object.defineProperty  方法定义了一个名为  x  的可读/写属性。 configurable 、 enumerable  和  writable  属性分别设置为  true ,表示可以删除、枚举和修改属性。 value  属性设置为  0 ,表示属性的初始值。 getter  和  setter  属性分别定义了读取和写入属性时调用的函数。

使用中常见的问题

在使用属性描述符时,需要注意以下几个问题:
 
-  configurable  属性为单向操作,设置为  false  后无法再改为  true ,且该属性不可删除。
-  enumerable  属性不能由  true  改为  false ,反过来也不行。
-  writable  属性可以由  true  更改为  false ,但不能反过来。
- 所有方法创建都是浅不变性,只会影响目标对象和它的直接属性。如果属性值为对象,其内容仍然是可变的。
- 在  get  和  set  方法中不要提及使用到属性描述符定义的对象属性,否则会陷入无限递归,导致栈溢出报错。
- 数据描述符和存取描述符都具备  configurable 、 enumerable  属性。
- 描述符不具备  value , writable , set  和  get  任意一个关键字都被认作一个数据描述符。
-  value  或  writable  和  get 、 set  不能同时存在,只要定义了  set  和  get  或其中一个就是一个存取描述符。
- 属性描述符必须是数据描述符或者存取描述符两种形式之一,不能同时是两者。


下面是一个示例,展示了如何使用  Object.defineProperty()  方法来处理属性的默认值:
 
// 创建一个名为 myObject 的对象
let myObject = {};

// 使用 Object.defineProperty() 方法定义一个名为 myProperty 的属性
Object.defineProperty(myObject, 'myProperty', {
  configurable: true,
  enumerable: true,
  value: 'Hello, World!',
  writable: true
});

// 打印 myObject 对象
console.log(myObject); 

 
 
在上述示例中,使用  Object.defineProperty()  方法定义了一个名为  myProperty  的属性,并设置了其默认值为  'Hello, World!' 。

这篇关于代码世界的构建有一个不可或缺的支柱(如何让代码更加稳健)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/736485

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...