作者AmosYang (泛用人型编码器)
看板Soft_Job
标题[心得][英文] 「属性」该用哪个字?
时间Fri Sep 18 11:43:53 2020
本周主题
* 「属性」该用哪个字?
* Attribute, Property 有什麽不一样?
结论:没有一定的标准。
* 在哲理上
* 「由外部因素赋予此物件的属性」,所谓 extrinsic property
* 称为 property, 也可称为 attribute
* 「此物件内在本质的属性」,所谓 intrinsic property
* 称为 property
* 在语源上
* attribute 偏向「赋予」;「由外部因素赋予此物件的属性」
* property 偏向「本质」;「此物件内在本质的属性」
* 在程式实作上,没有一定的标准。
* 下面列举了 C#, HTML, DOM 的例子。
---
* GitHub 讨论
https://bit.ly/321ResR
* Google 简报
https://bit.ly/32DAoAD
---
# Attribute, Property 有什麽不一样?
* 在哲理上
* 「由外部因素赋予此物件的属性」,所谓 extrinsic property
* 称为 property, 也可称为 attribute
* 「此物件内在本质的属性」,所谓 intrinsic property
* 称为 property
* 在语源上
* attribute 偏向「赋予」;「由外部因素赋予此物件的属性」
* property 偏向「本质」;「此物件内在本质的属性」
##
Attribute
* 语意:外部(extrinsic) / 关系(relational) 属性
* 由「与其它物件的关系」
赋予此物件的属性
* 例如,一个物件的「重量」;由此物件所处的重力场
赋予的属性
* 语源: 14 世纪後期,动词「
赋予、指派」,名词「对某人的评价」
* 在程式上
* 可表达物件、元素的属性
* 常用来表达「
属性的属性」
##
Property
* 语意
* 内部(intrinsic) 属性
* 物件
本质上的属性
* 例如,一个物件的「质量」
* 也可以代表 外部(extrinsic) / 关系(relational) 属性
* 语源: 1300 年代,
本质、特性
* 在程式上
* 可表达物件、元素的属性
# Attribute, Property 该用哪个字?
在程式实作上,不同语言、框架、环境对於「物件属性」这个观念的心智模型多少
有出入,并没有一定的标准。
我个人偏好 C# 的风格。
## 以 C# 为例
* 在「为东西加注资料(metadata)」的情景下,用 `
Attribute`
* 例如, `DebuggerBrowsableAttribute`
* 而「类别的属性」,称为 `
Property`
* 例如, `String.Length`
## 以 HTML / DOM 为例
HTML (
attribute) / DOM (
property) 则是用了不同的字来表达「东西的属性」。
引用
https://stackoverflow.com/a/53924373 的例子:
```
<input id="the-input" type="text"
value="Name:">
```
* 假设使用者在此输入栏位填上了 "foo"
* 接下来以 `<input>` 代表此 HTML 元素(element)
* 接下来以 `theInput` 代表此 DOM 物件
* 执行 theInput.
value 会得到 "foo"
* value 是 theInput 这个 DOM 物件的
property (属性)
* 执行 theInput.getAttribute('
value') 会得到 "Name:"
* `getAttribute()` 是 theInput 这个 DOM 物件的方法
* value 是 `<input>` 这个 HTML 元素的
attribute (属性)
## 参考资料
*
https://en.wikipedia.org/wiki/Attribute_(computing)
*
https://en.wikipedia.org/wiki/Property_(philosophy)#Intrinsic_and_extrinsic_properties
*
https://stackoverflow.com/a/53924373
*
https://www.etymonline.com/word/attribute
*
https://www.etymonline.com/word/property
*
https://www.lexico.com/en/definition/attribute
*
https://www.lexico.com/en/definition/property
感谢参与
https://github.com/EngTW/English-for-Programmers/issues/25 讨论
的网友。
---
这周比较忙,只研究了一个题目。 XD
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 136.56.13.184 (美国)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Soft_Job/M.1600400643.A.D04.html
※ 编辑: AmosYang (136.56.13.184 美国), 09/18/2020 11:44:41
※ 编辑: AmosYang (136.56.13.184 美国), 09/18/2020 11:46:46
1F:→ yoche2000: 推 09/18 12:06
2F:推 hans1461: 推 09/18 12:08
谢谢 :)
3F:→ chatnoir: vue跟react都用props传参数给child耶, 我要去发PR XDDD 09/18 12:17
我不熟 vue, react 及其架构理念;能不能谈谈你是为什麽想去发什麽样的 PR ? :)
※ 编辑: AmosYang (136.56.13.184 美国), 09/18/2020 12:25:38
4F:→ krazy1101: React 的 props 官方文件表示 properties 的缩写,但 09/18 12:29
5F:→ krazy1101: 行为比较像是从外部传值进入元件,刚好跟你写的定义相 09/18 12:29
6F:→ krazy1101: 反 09/18 12:29
谢谢你的说明 :)
这让我想到 C# 语言中,类别(class)的 "property" 也是支援 setter/getter 。
或许这要看这些语言、框架的设计者有没有留下纪录它当初思路、考量的文件,才
能知道它为什麽要这样设计、选用特定的字。
7F:推 easterday: 我也觉得attribute->内在,property->外在 09/18 12:40
8F:→ easterday: 这样的用法比较多 09/18 12:41
(延续上面的讨论)
或许可以这样想:
* 在哲理思维层级,
* 东西有质量(mass);质量是东西的 内部(intrinsic) 属性(property)
* 东西存在,就有质量;质量不受外部因素影响
* 东西有重量(weight);重量是东西的 外部(extrinsic) 属性(attribute)
* 东西有重量,是因为「这个东西」与「这环境的重力场」的关系
* 东西的重量受外部因素「重力场」的影响
* 在程式实作层级,可能是写成这样:
```C#
class Thing
{
public double MassInGrams { get; set; }
public double WeightInGrams { get; set; }
}
```
从 C# 语言层级来看, `MassInGrams`, `WeightInGrams` 都是 `Thing` 这个
类别(class)的属性(property)。
※ 编辑: AmosYang (136.56.13.184 美国), 09/18/2020 13:32:10
9F:推 virdust2003: 认同这篇 09/18 13:18
谢谢你的欣赏 :)
---
(延续上面的讨论)
我修改了上面的原文
# 旧
* 语意:内部(intrinsic) 属性
* 物件本质上的属性
* 例如,一个物件的「质量」
# 新
* 语意
* 内部(intrinsic) 属性
* 物件本质上的属性
* 例如,一个物件的「质量」
*
也可以代表 外部(extrinsic) / 关系(relational) 属性
# 参考资料
*
https://en.wikipedia.org/wiki/Property_(philosophy)#Intrinsic_and_extrinsic_properties
> An intrinsic property is a property that an object or a thing has of
> itself, independently of other things, including its context.
> An extrinsic (or relational) property is a property that depends on a
> thing's relationship with other things.
> The latter is sometimes also called an attribute, since the value of
> that property is given to the object via its relation with another
> object.
※ 编辑: AmosYang (136.56.13.184 美国), 09/18/2020 13:49:45
10F:推 chatnoir: 感谢k大帮我解释 ~ 我只是开玩笑的 09/18 14:19
我觉得那是很有意思的题目,也让我发现了我的文章最原始的版本写得不够清楚;
希望推文中的後续讨论、补充说明有帮助 :)
※ 编辑: AmosYang (136.56.13.184 美国), 09/18/2020 14:37:57
11F:→ ChungLi5566: 对岸是翻成固有属性跟自定义属性 09/18 14:47
谢谢补充资讯 :)
12F:推 DCTmaybe: 请问有argument,parameter系列吗? 09/18 15:08
有,可以参考
*
https://webptt.com/cn.aspx?n=bbs/Soft_Job/M.1597982849.A.9A7.html
* 或 Google 简报
https://bit.ly/3l161ey 第 17 页
---
这系列文章的列表:
https://github.com/EngTW/English-for-Programmers
也有列出每个文章的主要关键字,可以用 CTRL-F 找你想查的字。
13F:推 CoNsTaR: argument, parameter 问题出在中文没有适合的词来翻 argu 09/18 17:07
14F:→ CoNsTaR: ment,所以只好都叫参数吧... 09/18 17:07
15F:→ Jockey66666: argument(引数) parameter(参数) 蛮多这样翻的吧 09/18 20:08
是的,我查到的也是这样翻:
* 方法、函数宣告的是参数 (parameter)
* 传入方法、函数的是引数 (argument)
16F:推 LERICAL: 推 09/18 20:38
谢谢 :)
---
文章编辑说明;希望这样子能更清楚 :)
# 旧:「哲理、语意」混在一起
* 在哲理、语意上
* attribute 偏向「由外部因素赋予此物件的属性」
* property 偏向「此物件内在本质的属性」
# 新:「哲理、语意」分开来说
* 在哲理上
* 「由外部因素赋予此物件的属性」,所谓 extrinsic property
* 称为 property, 也可称为 attribute
* 「此物件内在本质的属性」,所谓 intrinsic property
* 称为 property
* 在语源上
* attribute 偏向「赋予」;「由外部因素赋予此物件的属性」
* property 偏向「本质」;「此物件内在本质的属性」
※ 编辑: AmosYang (136.56.13.184 美国), 09/18/2020 21:25:21
17F:→ KanzakiHAria: C++attribute从外面给属性 vcproj property是本质 09/21 21:16
感谢提供实例 :)
18F:推 candycan: 讲到「属性」就会想到「设定」,好像很容易搞混… 09/22 12:56
是的。
在脸书那边的讨论有个很有意思的题目:「要怎麽表达『杰尼龟的属性是水』?」
这时候就要分析「属性」想表达的 语意 究竟为何 。
最後整理出来,比较完整的说法是
* "PokemonPowerType" 是「杰尼龟的属性 (之一)」
* 杰尼龟的 Pokemon Power Type 是水。
那就可以视上下文脉络,可以有像是以下的选择:
* 杰尼龟.PokemonPowerType = Water
* 杰尼龟.PowerType = Water
* 杰尼龟.Type = Water
19F:推 bug2: 谢谢分享 很有价值的讨论与实用范例 09/25 10:18
谢谢 :) 有任何问题、建议,欢迎提出来讨论 :)
※ 编辑: AmosYang (136.56.13.184 美国), 09/25/2020 11:38:04