社区
JavaScript
帖子详情
prototype.js 1.4,1.5中一个诡异的代码冲突,关于hash对象的,搞了一个小时才发现
Go_Rush
2006-08-21 02:58:18
其实不能说是bug
看我郁闷的代码
var hash={member:1,test:2,ids:3}
alert(hash.member)
alert($H(hash).inspect())
alert($H(hash).toQueryString())
hash.member实际是存在的
但是.inspect() 和 .toQueryString()却当它不存在
...全文
518
6
打赏
收藏
prototype.js 1.4,1.5中一个诡异的代码冲突,关于hash对象的,搞了一个小时才发现
其实不能说是bug 看我郁闷的代码 var hash={member:1,test:2,ids:3} alert(hash.member) alert($H(hash).inspect()) alert($H(hash).toQueryString()) hash.member实际是存在的 但是.inspect() 和 .toQueryString()却当它不存在
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
6 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
harryCom
2006-08-21
打赏
举报
回复
晕..没看到二楼的回复
harryCom
2006-08-21
打赏
举报
回复
不要用这些关键字就可以了:
Enumerable
{...}
each: {...}
all: {...}
any: {...}
collect: {...}
detect: {...}
findAll: {...}
grep: {...}
include: {...}
inject: {...}
invoke: {...}
max: {...}
min: {...}
partition: {...}
pluck: {...}
reject: {...}
sortBy: {...}
toArray: {...}
zip: {...}
inspect: {...}
map: {...}
find: {...}
select: {...}
member: {...}
entries: {...}
harryCom
2006-08-21
打赏
举报
回复
member是Enumerable对象的成员,会在这里被改写:
function $H(object) {
var hash = Object.extend({}, object || {});
Object.extend(hash, Enumerable); // member属性被Enumerable对同名属性的重写了
Object.extend(hash, Hash);
return hash;
}
return之前加个断点可以看到member的属性是:
hash.member
{...}
bindAsEventListener: {...}
bind: {...}
ice_berg16
2006-08-21
打赏
举报
回复
命名空间,或换名字
Go_Rush
2006-08-21
打赏
举报
回复
不知道各位有什么好的方法来解决这些 冲突
Go_Rush
2006-08-21
打赏
举报
回复
问题找到了
var Hash = {
_each: function(iterator) {
for (key in this) {
//这里 如果key是 "member",value将得到一个函数对象,而不是期望的值1
var value = this[key];
//所以下面这句将被执行
if (typeof value == 'function' ) continue;
var pair = [key, value];
pair.key = key;
pair.value = value;
iterator(pair);
}
},
member 是Enumerable的一个方法
Object.extend(Enumerable, {
map: Enumerable.collect,
find: Enumerable.detect,
select: Enumerable.findAll,
member: Enumerable.include,
entries: Enumerable.toArray
});
而他,则把这个方法塞给了哈希对象
function $H(object) {
var hash = Object.extend({}, object || {});
Object.extend(hash, Enumerable);
Object.extend(hash, Hash);
return hash;
}
前端工程师能力坐标图:从功能实现到工程决策的跃迁
本文提出以问题域驱动的前端工程实践框架,覆盖状态管理(微前端下Redux store隔离)、构建优化(Vite依赖预构建避坑、Turborepo三重缓存)、性能监控(Sentry分级上报+Web Worker卸载)及可审计发布流水线(Git Hooks左移审计、语义化版本自动化)。强调从功能实现到工程决策的跃迁,聚焦真实业务约束下的系统性选型与权衡,拒绝黑盒式方案,要求开发者具备全链路视角与工程意识。
JavaScript
87,990
社区成员
224,684
社区内容
发帖
与我相关
我的任务
JavaScript
Web 开发 JavaScript
复制链接
扫一扫
分享
社区描述
Web 开发 JavaScript
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章