- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
嗨,我有以下类(class):
const MyClass = function MyClass() {
this.state = null;
}
MyClass.prototype.set = function(key, value) {
this[key] = value;
}
以及其他模块中的以下枚举:
const enumeration = {
ACTIVE: 'active',
PENDING: 'pending',
DONE: 'done'
}
我想知道处理枚举属性的 setter 的最佳实践/约定是什么(在此处说明)
我可以做这样的事情:
let myClass = new MyClass();
myClass.set('state', enumeration.PENDING);
但它有点冗长,我需要了解 myClass 模块和 enum 模块。
另一个想法是这样做:
const MyClass function MyClass() {
this.state = null;
}
MyClass.prototype.setPending = function() {
this.state = enumeration.PENDING;
}
并允许调用myClass.setPending()
但我不知道这种 setter 的正确命名。
最佳答案
首先,我认为这个问题不是基于意见,而是基于需求。如果您说它是基于偏好的,则意味着您根本没有遇到建立最佳实践来避免的问题。考虑到这一点,第一个最佳实践是使其尽可能简单。 API 如何发展取决于应用程序的特定需求以及您发现最合适的 API 的能力。
下面是 Web FTP 客户端上传对象的“代码演变”示例。请注意,有很多不同的可能路径。此示例的唯一目的是证明最佳实践不仅仅是偏好问题。
你从这个开始:
function Upload(state) {
this.state = state || 'pending';
this.elem = document.createElement('div');
}
new Upload().state = 'active';
然后您意识到您需要一个进度条 View 来在设置状态时进行更新,因此您创建了一个专门的 setter :
Upload.prototype.setState = function(value) {
this.state = value;
this.elem.className = 'state-' + this.state;
};
但是稍后您决定需要显示通知,但仅当状态设置为“完成”时才显示。或者,您可能发现自己需要一种简写方法,因为您必须多次输入 upload.setState('done')
并且发现输入 upload.setStateDone()
更容易(参见 jQuery 的 $.get
与 $.ajax
)。
Upload.prototype.setStateDone = function() {
this.setState('done');
// code to execute only when the state changes to 'done'
};
请注意,您可以更喜欢一致的 API 而不是便利性(例如,我确实更喜欢 $.get
而不是 $.ajax
,因为使用后者会产生很大的开销,但我更喜欢使用 jQuery 的 $(elem).on('click',..
而不是 $.click
因为它所做的只是预填充 'click' 字符串)。
setter 仍然存在问题:如果您设置了无效状态,例如'whatever',它将附加类 'state-whatever',因此您更新 setState
:
Upload.prototype.setState = function(value) {
if (['active', 'pending', 'done'].indexOf(value) > -1)
this.state = value;
this.elem.className = 'state-' + this.state;
};
问题是,您的状态被硬编码在方法中,并且您希望在其他组件中重用它们,因此您定义一个状态映射并调整 setState
。为了避免硬依赖,您可以使用依赖注入(inject),而不是在构造函数内引用全局 states
映射:
var states = {
ACTIVE: 'active',
PENDING: 'pending',
DONE: 'done'
};
function Upload(state, states) {
this.states = states;
this.state = state || this.states.PENDING;
this.elem = document.createElement('div');
}
Upload.prototype.setState = function(value) {
var states = Object.keys(this.states).map(function(key) {
return key.toLowerCase();
});
if (states.indexOf(value) > -1) {
this.state = value;
this.elem.className = 'state-' + this.state;
};
顺便说一句,setter 最基本的形式只是一个将属性设置为对象值的函数。其具体程度取决于您硬编码到 setter 中的参数数量。
function createSetter(context, prop, val) {
switch (arguments.length) {
case 0:
return function(p, v) { this[p] = v; };
case 1:
return function(p, v) { this[p] = v; }.bind(context);
case 2:
return function(v) { this[prop] = v; }.bind(context);
case 3:
return function() { this[prop] = val; }.bind(context);
}
}
var genericSetter = createSetter(); // any prop/val, implicit this context,
boundSetter = createSetter({}); // any prop/val, fixed context
propSetter = createSetter({'hello': 'world'}, 'hello') // fixed prop, any val, defined context
propValSetter = createSetter({'hello': 'world'}, 'hello', 'dude') // fixed prop, fixed val, fixed context
关于javascript - 类枚举 setter ,约定 javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46140531/
假设我有一个函数,例如 f(x,y)但y参数是可选的。设置y的首选方式是什么?作为可选参数?对我有用的一种选择: function f(x, y=nothing) # do stuff
在学习核心动画时,我很快就了解到,如果你做得不对,你会得到非常奇怪的未定义行为。为此,我有几个问题可以帮助我从概念上更好地理解它。 我的 NSView 子类在其 init.h 中声明以下内容:该 Vi
我一直在尝试学习 ClojureScript,并偶然发现了一些非常神秘的函数名称。 例如: (.-length str) 来自 om 文档: (defn add-contact [data owner
我对此很好奇。我最近想到使用大括号来隔离代码段,以进行可视化组织,并将变量隔离到特定范围(如果只是为了防止它们在较大的函数中混淆 Eclipse 中的建议)。例如: public void start
所以我进行了一些搜索,但在 Google 或 PEP 上找不到任何讨论此问题的内容。 我正在使用 tkinter 做一个项目,我有一个文件,它是项目的一部分,只有 200 行代码(不包括所有注释掉的代
根据某种不成文的约定,所有 API key 都是十六进制数字吗? 最佳答案 对一些半随机数据(例如时间戳 + 用户 ID + key )进行 md5 哈希是一种快速生成难以猜测的固定长度 key 的方
在 C 中,如果编译器想要提供实现定义的标识符(语言扩展、内在函数、伪函数和伪宏,基本上任何不是语言标准保留关键字但也不是常规函数的东西)惯例是名称以下划线为前缀;据了解,代码不应出于正常目的使用此类
Java Bean 的约定之一是: setter 的返回类型必须是 void。 或者至少大多数人是这么说的。我的问题是:它真的必须无效吗?我喜欢返回 "this" 而不是 "void" 因为我可以像这
我对 Java 编码风格有疑问。 我编码: public class Pattern { public Pattern(...) { ... } public static List
我有一个关于 Java servlet 约定的问题。在查看 servlet 的任何教程时,无论是 Eclipse、NetBeans 等,它们总是让您创建一个 index.jsp 页面。创建页面后,他们
在 python 中,当变量名与保留字冲突时(如 class、in、default 等),PEP8约定规定应使用尾随下划线(class_、in_、default_)。 对于相同的情况,共享最多的 ja
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 5 年前。 Improve
Java 存储预定义字符串集的主要约定是什么?现在我有一个包含我使用的所有字符串的类,但感觉确实有更好的方法来做到这一点。 这就是我在 my_strings.java 类中所做的 public fin
我经常需要检索结果并按给定列访问它们。 有没有一种方法可以不用每次都遍历整个数据集来编写它? 我研究了各种 PDO 获取模式,但没有发现比这更简单的模式。谢谢。 function get_groups
所以我正在制作这个 android 应用程序,它需要从用户提供的 CSV 文件中读取数据。 CSV 文件在台式电脑上编辑起来更舒服,所以我在应用程序中没有编辑器,它是“只读”的;我假设手机的 SD 卡
我正在编写一个文件,该文件是 npycurses module 的子类 npycurses.ActionFormV2 ,我正在覆盖 beforeEditing method ,所以当我整理我的文件时,
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
我正在开发一个可在 iPhone、iPad 和其他移动设备上运行的网页。我很好奇是否有关于移动设备 CSS 最佳实践的资源。 我试过搜索,但想出了随机网站 with tidbits of inform
我发现开始编程时最大的挑战之一是掌握文件路径。例如,当您引用目录结构中同一级别的文件夹中的路径时,您将看到: /folder/style.css 或 文件夹/style.css等 当您引用不同的文件时
如果我有如下函数: def foo(): return 1, 2 我通常会这样调用函数: g, f = foo() 但是,如果我从不打算使用返回的第二个值,是否有一种调用函数的方法可以明确说明
我是一名优秀的程序员,十分优秀!