Soft_Job 板


LINE

本周主题 * 「属性」该用哪个字? * 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







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:Soft_Job站内搜寻

TOP