- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我正在插件/库中编写一个小的缓存函数。它接受一个 HTMLElement
并返回一个 Decorator。
return function _cache(elem) {
if (elem.id === "") {
elem.id = PLUGIN_NAME + "_" + uid++;
}
if (cache[elem.id] === void 0) {
cache[elem.id] = _factory(elem);
}
return cache[elem.id];
}
在这里,我通过 HTMLElement
的 id
将一些昂贵的操作存储在缓存中。这是一个 O(1)
查找,但它使用了设置 elem.id
并产生副作用的“不良做法”。
另一种方法是在缓存中查找O(N)
return function _cache(elem) {
for (var i = 0, ii = cache.length; i++) {
var o = cache[i];
if (o.elem == elem) return o.data;
}
var ret = _factory(elem);
cache.push({ elem: elem, data: ret });
return ret;
}
但这意味着我缓存的昂贵方法对 HTMLElement
没有任何副作用。
问题:
这种“副作用”是无辜的吗?值得对我的装饰器进行优化吗?
真实代码:
Gist of plugin template where I use this snippet
编辑:
我显然太累了,忘记了 data-foo
的存在。下面是它应该如何实现
var attr = "data-" + PLUGIN_NAME + "-cache";
return function _cache(elem) {
var val = elem.getAttribute(attr);
if (val === null || val === "") {
val = PLUGIN_NAME + "_" + uid++;
elem.setAttribute(attr, val);
}
if (cache[val] === undefined) {
cache[val] = _factory(elem);
}
return cache[val];
}
最佳答案
不使用 id
,而是使用 data-x
- 这就是它的创建目的。
id
有一个特定的含义,看到它自动生成会让人感到困惑(即使有适当的记录,这几乎永远不会。)你也有轻微的覆盖机会。
关于javascript - 将 element.id 设置为副作用是不好的做法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6272128/
如果您想分享更多信息,可以在这里找到整个资源 指针: https://github.com/sergiotapia/DreamInCode.Net 基本上,我的API将为其他开发人员提供
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
我不是 SCM 工具的经验丰富的用户,尽管我确信它们的用处,当然。 我在以前的工作中使用了一些不起眼的商业工具,在当前的工作中使用了 Perforce,并在我的小型个人项目中使用了 TortoiseS
所以我想知道一些我应该避免在 javascript 中做的事情以获得良好的 SEO 排名。在我的下一个站点中,我将广泛使用 jquery 和 javascript,但不想牺牲 SEO。那么您认为我应该
基本上,我想知道什么是避免 future CSS 代码出现问题和混淆的最佳方法... 像这样命名 CSS 属性: div#content ul#navigation div.float-left (真
我是一名优秀的程序员,十分优秀!