JavaScript 工具库:Cloudgamer JavaScript Library v0.1 发布

研究了一年多的js,也差不多写一个自己的js库了。
我写这个不算框架,只是一个小型的js工具库,所以我用的名字是Library。
主要集合了我写js时一些常用的方法,并参考了prototype.js,jquery,google,百度,有啊等框架。

这个工具库的主要特点是:

【跨浏览器】
能在以下浏览器使用:IE6,IE7,IE8,Firefox 3.5.3,Chrome 3.0,Safari 4.0.3,Opera 10.10
ie系列是必须的,其他能支持最新版本就够了。

【使用命名空间】
当然不是真正“命名空间”,只是一些全局变量,用途相似而已。
有如下命名空间:
$$:代表Object,保存对象相关方法,也代替最常用的getElementById方法;
$$B:代表Browser,保存浏览器信息;
$$A:代表Array,保存数组和类数组的相关方法;
$$F:代表Function,保存函数的相关方法;
$$D:代表Dom,文档对象的相关操作和方法;
$$E:代表Event,dom事件的相关操作和兼容处理;
$$CE:代表CustomEvent,用于程序对象的自定义事件;
$$S:代表String,保存字符串的相关方法。
虽然我不反对有节制地扩展原生对象,但可以的话还是避免命名污染吧。
用多个命名空间(而不用单个)只因管理容易,用起来方便。
用两个$,不是要更多美刀(虽然很想),而是避免跟流行的框架冲突。
使用全部变量时我没有用window.x的形式,因为那样会导致一些问题,具体参考这里

【使用匿名函数】
貌似是jquery发扬光大的,就是把代码嵌在一个function里面。
其实就是利用闭包,一来可以使用局部变量,二来可以防止命名冲突。

【使用对象检测】
“对象检测天生地优于浏览器检测”,出自“ppk谈JavaScript”的真理。
能用对象检测的都尽量用,当然有些实在太难搞的也不要太执着。
对象检测方面jQuery的support做的很好,建议去看一下。


追求目标是:

【小体积】
这里的体积不是说字符的多少,而是属性和方法的数量。
工具库的属性和方法必须是很有用的,最好是“不得不加”的。
当然随着使用的增加,工具库也会慢慢的扩大,但要坚持这个原则。

【高效率】
高效是不变的追求,当然是在权衡利弊之后。
说到高效不得不佩服一下google,它不但代码追求效率,而且下载的代码是已经经过浏览器检测的。
具体可以自己用各个浏览器下载看看试试。


建立目的是:

【整合常用方法】
把常用的方法整合到一起,既利于代码复用,也便于维护。
但也不可避免地添加一些无关的方法,从而增加了代码量,降低了效率。

【解决兼容问题】
解决一些常见的兼容性问题,减轻编码负担。


各个部分说明

【Object】

命名空间是:$$

$$本身就是最常用的方法:document.getElementById
它还包括以下几个方法:extend、deepextend和wrapper。
其中extend跟prototype.js的Object.extend是一样的,用来扩展对象,是用得最久的方法之一了。
而deepextend是深度扩展,这里的深度跟深度复制里面的意思差不多,参考的是jQuery的extend。

emptyFunction保存了一个空的function,主要用来代替空function节省资源。

wrapper就复杂一点,主要用来做继承,主要参考有啊的$extends(跟prototype的Class.create也类似)。
wrapper是$extends的简化版,只保留了关键的几个部分:

代码
O.wrapper = function(me, parent) {
    
var ins = function() { me.apply(this, arguments); };
    
var subclass = function() {};
    subclass.prototype 
= parent.prototype;
    ins.prototype 
= new subclass;
    
return ins;
};


跟传统原型继承的区别是用了一个空的函数作为初始化程序,防止非prototype属性方法的继承。


【Browser】

命名空间是:$$B

通过userAgent获取浏览器信息,主要获取浏览器的类型和版本。
这里基本是参考有啊的Browser,要了解这部分首先要知道各浏览器的userAgent。
下面是各浏览器(ie系列和其他浏览器的最新版)的userAgent:
ie6
Mozilla/4.0 (compatible; MSIE 6.0; ...)
ie7
Mozilla/4.0 (compatible; MSIE 7.0; ...)
ie8
Mozilla/4.0 (compatible; MSIE 8.0; ...)
ff
Mozilla/5.0 (...) Gecko/20090824 Firefox/3.5.3
chrome
Mozilla/5.0 (...) AppleWebKit/532.0 (KHTML, like Gecko) Chrome/3.0.195.27 Safari/532.0
safari
Mozilla/5.0 (...) AppleWebKit/531.9 (KHTML, like Gecko) Version/4.0.3 Safari/531.9.1
opera
Opera/9.80 (...) Presto/2.2.15 Version/10.10

先通过判断特有字符来判断浏览器类型:

var b = {
    msie: 
/msie/.test(ua) && !/opera/.test(ua),
    opera: 
/opera/.test(ua),
    safari: 
/webkit/.test(ua) && !/chrome/.test(ua),
    firefox: 
/firefox/.test(ua),
    chrome: 
/chrome/.test(ua)
};


获取版本信息就比较麻烦,有啊Browser的方法就比较巧妙(有修改):

var vMark = "";
for (var i in b) {
    
if (b[i]) { vMark = "safari" == i ? "version" : i; break; }
}
b.version 
= vMark && RegExp("(?:" + vMark + ")[\\/: ]([\\d.]+)").test(ua) ? RegExp.$1 : "0";

但参考上面的userAgent会发现opera的获取应该也是用"version"才对啊,问题是它在10之前的userAgent是这样的:
Opera/9.99 (...) Presto/9.9.9
并没有用"version",为了适用大部分情况还是不要用"version"好了,而且这个判断用的也不多。


【Array】

命名空间是:$$A

里面包括以下方法:isArray, forEach, map, filter, every, some, indexOf, lastIndexOf
以上方法除了isArray,都是JavaScript 1.6里数组增加的方法。

其中isArray用来判断对象是否数组,indexOf和lastIndexOf是元素定位方法,其他几个是迭代方法。
在自定义的这些迭代方法,不但能应用在数组上,还能应用在类数组,像NodeList,arguments这些对象,也能应用在一般的对象上。

这里我参考了爱民的JSEnhance.js的数组扩展部分,对这几个自定义迭代方法中相同的结构进行整合。
首先定义一个基本的迭代函数each:

Code

当有length属性(数组或类数组)时根据索引迭代,否则用for...in历遍对象的属性。
由于在方法的说明中规定了"elements that are deleted are not visited",所以要用if (i in object)来判断一下。
要注意的是当callback返回false时会跳出循环,利用callback的返回值,就可以在callback内部间接控制外部的跳出操作了。

然后准备自定义的迭代方法:

代码
each({
        forEach: 
function( object, callback, thisp ){
            each( object, 
function(){ callback.apply(thisp, arguments); } );
        },
        map: 
function( object, callback, thisp ){
            
var ret = [];
            each( object, 
function(){ ret.push(callback.apply(thisp, arguments)); });
            
return ret;
        },
        filter: 
function( object, callback, thisp ){
            
var ret = [];
            each( object, 
function(item){
                    callback.apply(thisp, arguments) 
&& ret.push(item);
                });
            
return ret;
        },
        every: 
function( object, callback, thisp ){
            
var ret = true;
            each( object, 
function(){
                    
if ( !callback.apply(thisp, arguments) ){ ret = falsereturn false; };
                });
            
return ret;
        },
        some: 
function( object, callback, thisp ){
            
var ret = false;
            each( object, 
function(){
                    
if ( callback.apply(thisp, arguments) ){ ret = truereturn false; };
                });
            
return ret;
        }
    }

迭代部分给each来做,这里只要控制callback的具体操作就可以了。
这里利用了闭包,使callback可以修改迭代方法的返回值。
every和some就利用callback的返回值跳出循环。

定义好这些方法后,再用each历遍这些方法,并加入到命名空间中:

Code

在方法执行时,会先判断对象本身有没有指定的方法,没有的话才使用自定义的迭代方法。


【Function】

命名空间是:$$F

里面现在只有两个方法:bind和bindAsEventListener。
这两个是prototype.js里面的经典方法了,是用来给function绑定this的。
原理是利用call/apply改变调用方法的对象:

var args = slice.call(arguments, 2);
return function() {
    
return fun.apply(thisp, args.concat(slice.call(arguments)));
}

其中用到Array.prototype.slice把arguments对象转成数组,不知道是谁发现的,知道这个用法就行了。
ps:不止slice,其他像concat,join等也能这样使用。

bindAsEventListener跟bind不同的是会把第一个参数设定为event对象,专门用在事件回调函数中:

var args = slice.call(arguments, 2);
return function(event) {
    
return fun.apply(thisp, [E.fixEvent(event)].concat(args));
}

其中用到fixEvent处理event的兼容性,后面Event的部分会详细说明。


【Dom】

命名空间是:$$D

这部分是工具库中最大,最复杂也最重要的部分。
主要是储存了一些Dom操作,并解决一般的兼容性问题。

其中getScrollTop和getScrollLeft分别是获取文档滚动的scrollTop和scrollLeft。
一般来说如果在标准模式下应该用documentElement获取,否则用body获取。
但chrome和safari(都是用WebKit渲染引擎)即使在标准模式下也要用body来获取。
这里用的方法是:

var doc = node ? node.ownerDocument : document;
return doc.documentElement.scrollTop || doc.body.scrollTop;


优先获取documentElement的再选择body的,这样就基本能解决了。
但这个其实是不完善的,如果给文档添加如下样式:

body{height:300px;overflow:scroll;width:500px;}

在ie6/7会发现在标准模式下body的部分会按指定高度和宽度呈现,而且能带滚动条。
就是说documentElement和body能各自设置scrollTop。
那这个时候该获取哪个就说不清了,还好一般情况并不需要这样设置的(至少我是没碰过)。
对于这样的特例,知道有这个情况就行了,没必要为了它增加太多代码。
ps:获取的scrollLeft/scrollLeft是不会有负值的。

contains方法是判断参数1元素对象是否包含了参数2元素对象。
主要利用ie的contains和w3c的compareDocumentPosition来判断。
具体参考这里的比较文档位置部分

有两个元素坐标相关的方法:rect和clientRect。
其中rect是相对浏览器文档的位置,clientRect是相对浏览器视窗的位置。
当支持getBoundingClientRect时,利用它配合getScrollLeft/getScrollTop获取文档位置。
否则用循环获取offsetParent的offsetLeft/offsetTop的方式获取。
具体参考这里的比较元素位置部分

还有三个样式相关的方法:curStyle、getStyle、setStyle
curStyle是用来获取元素的最终样式表的,根据支持情况返回getComputedStyle(w3c)或currentStyle(ie)。
ps:这里要优先判断getComputedStyle,因为opera也支持currentStyle。

getStyle是用来获取元素指定样式属性的最终样式值的。
支持getComputedStyle的直接用它获取样式的computed value就行,关于computed value可以参考这里
而currentStyle虽然跟getComputedStyle有点像都是获取最终样式,但两者得到的值的形式是不同的。
它不像getComputedStyle那样返回渲染完成后准确的规格统一的值,而只是一个设置值。
而且这个值还不一定就是渲染后的准确值。
程序主要做的就是在ie中尽量获取接近getComputedStyle的值。

首先是处理透明度,ie虽然用的是滤镜但它的值除以100就跟w3c的"opacity"的值一样了: 

if (/alpha\(opacity=(.*)\)/i.test(style.filter)) {
    
var opacity = parseFloat(RegExp.$1);
    
return opacity ? opacity / 100 : 0;
}
return 1;

还有"float",这个比较简单换成"styleFloat"就行了。

获取样式后还有一个工作是转换单位。当判断得到的值是一个数值而单位又不是px的话,就会进行转换。
方法是参考jQuery的curCSS的,理解之前先认识两个比较少用的属性:runtimeStyle和pixelLeft。

runtimeStyle是ie特有的属性,用法跟style差不多,但它有着最高的优先级。
就是说如果在runtimeStyle设置了样式就会忽略掉style中同样的样式。
具体可以参考birdshome的“关于HTML Object中三个Style实例的区别”和“关于使用runtimeStyle属性问题讨论
而pixelLeft的作用是以像素px为单位返回元素的left样式值,ie(还能用在runtimeStyle)和opera支持。

知道这两个东西后,就能理解它的原理了:
1,先备份原来的值:

style = elem.style, left = style.left, rsLeft = elem.runtimeStyle.left;

2,设置runtimeStyle的left为currentStyle的left:

elem.runtimeStyle.left = elem.currentStyle.left;

目的是利用runtimeStyle的优先级保证修改style后能按原来的样式显示;
3,设置style的left为要转换的值,并巧妙地利用pixelLeft获取这个值的px单位形式:

style.left = ret || 0;
ret 
= style.pixelLeft + "px";

4,最后恢复原来的left值:

style.left = left;
elem.runtimeStyle.left 
= rsLeft;

这样就能在不改变渲染样式的情况下转换成像素值了。
ps:jQuery中有说明这个方法也是Dean Edwards提出的,神啊。

最后还有一个setStyle用来设置样式,主要用来批量设置样式和解决一些兼容问题。
可以用以下两种方式的调用:
$$D.setStyle(元素或元素集合, { 样式属性名: 属性值, ... })
$$D.setStyle(元素或元素集合, 样式属性名, 属性值)
第一个参数是要设置样式的元素或元素集合,如果是单个元素会自动转成单元素集合:

if (!elems.length) { elems = [ elems ]; }


第二个参数是一个键值对集合,键是样式属性名,值是对应的属性值。
如果只设置一个样式,可以设第二个参数是样式属性名,第三个参数是属性值,由程序新建一个键值对集合:

if (typeof style == "string") { var s = style; style = {}; style[s] = value; }


再用forEach历遍元素集合,绑定的函数里给元素设置用for in列出的所有样式。
ps:单个元素设置单个样式应该直接设置,除非是有兼容问题。

剩下的就是解决兼容问题了。
首先是透明度,ie是用滤镜的,如果直接设置filter会把其他滤镜都替换没了。
参考jQuery的方法,先获取原来的filter,替换掉透明滤镜的部分,再加上要设置好的透明滤镜:

elem.style.filter = (elem.currentStyle.filter || "").replace( /alpha\([^)]*\)/"" ) +
    
"alpha(opacity=" + value * 100 + ")";


挺巧妙的方法,记得值要乘以100对应w3c的"opacity"。

至于"float"就比较简单,ie用"styleFloat"其他用"cssFloat"就行了。


【Event】

命名空间是:$$E

这个是兼容性的老问题了,这里包含三个方法:addEvent,removeEvent,fixEvent。

addEvent和removeEvent分别是添加和移除事件,以前我是用ie的attachEvent跟w3c的addEventListener做兼容。
但看到Dean Edwards的方法后,就改用他的了,除了兼容性更好外还能解决一些bug(详细看这里的cloneNode的bug部分)。
代码中的addEvent/removeEvent根据需要在Dean代码的基础上做了些修改,不过原理还是一样的。
还兼容了"mouseenter"和"mouseleave"事件。

而fixEvent是用来修正event对象的兼容性的,主要是添加一些w3c的属性和方法,上面bindAsEventListener就用到了它。
这里我只做了ie的兼容,其他都是直接使用event,这样就做不到细致的兼容,不过够用就行了。
jQuery的fix就做的比较完善,值得研究。


【CustomEvent】

命名空间是:$$CE

上面的Event只能用在dom事件上,但程序有时会需要一些“自定义”事件。
CustomEvent就是用在程序的自定义事件的。

这里主要仿照Event来做的,也包括addEvent和removeEvent,还有一个fireEvent方法用于手动触发事件。
它的主要用途是给程序添加钩子(hook),能同时添加多个程序。


【String】

命名空间是:$$S

我比较少做String的高级应用,所以暂时也没什么方法需要放进来。
里面有一个camelize方法,用来把横杠形式的字符串(例如"border-top")转换成驼峰形式(例如"borderTop")。
原理是利用replace第二个参数是function时的技巧:

return s.replace(/-([a-z])/ig, function(all, letter) { return letter.toUpperCase(); });

这个可以用在样式属性名的转换,在getStyle/setStyle中就使用了它。


调用方式

最后说说调用方式,跟调用一般函数方法是一样的,只是前面要带上命名空间。
例如:$$.extend(...)
像$$由于本身就是function,可以直接这样用:$$(...)
链式调用或许比较酷,但不太适合用在这样的工具库上,除非是扩展原生对象(这里也没有使用)。

 

版本下载
Cloudgamer JavaScript Library v0.1
完整版本  压缩版本

转载请注明出处:http://www.cnblogs.com/cloudgamer/

如有任何建议或疑问,欢迎留言讨论。

如果觉得文章不错的话,欢迎点一下右下角的推荐。

程序中包含的js工具库CJL.0.1.min.js,原文在这里

posted @ 2009-10-29 08:19 cloudgamer 阅读(37965) 评论(142) 编辑 收藏

评论共2页: 上一页 1 2 
 回复 引用 查看   
#43楼[楼主] 2009-11-24 09:02 cloudgamer      
@studyer
destination[pro] = arguments.callee(destination[pro] || {}, copy);
右边生成的是一个新对象,当然要赋值啊
你自己先理解一下吧
做一些测试,不要只想

 回复 引用 查看   
#44楼 2009-12-16 22:14 HappyTony      
学习
 回复 引用   
#45楼 2009-12-24 15:24 studyer[未注册用户]
问下 博主
你的Array扩展类里面 ff下没有给扩展from属性

那么IE 和 FF不一致了?

比如lastIndexOf(arr, 6, 3); 第三个参数 对于FF来说不起作用了?

 回复 引用 查看   
#46楼[楼主] 2009-12-24 15:59 cloudgamer      
@HappyTony
欢迎

 回复 引用 查看   
#47楼[楼主] 2009-12-24 16:02 cloudgamer      
@studyer
对哦,漏了
这个比较少用
谢谢提醒

 回复 引用 查看   
#48楼 2009-12-27 13:39 funny zak      
很不错,一直想写来这,现在你写了,我会在上面扩展,觉的够好就发给你副本。哈哈~谢谢拉
 回复 引用 查看   
#49楼 2009-12-27 13:43 funny zak      
写的很不错,学到不少,收益良多,再次感谢下!
 回复 引用 查看   
#50楼[楼主] 2009-12-27 13:45 cloudgamer      
@funny zak
呵呵
谢谢支持

 回复 引用   
#51楼 2009-12-28 10:01 studyer[未注册用户]
document.write(lastIndexOf([1,3,3,3,32,3,2,5,6,87], 3));
-->
好像lastIndexOf在js1.6下的实现有问题. 楼主用你的方法 试试, 看看IE FF的结果.. 估计在FF下 需要做个参数安全性检测.

 回复 引用 查看   
#52楼[楼主] 2009-12-28 10:50 cloudgamer      
@studyer
确实有问题
谢谢^_^

 回复 引用 查看   
#53楼 2010-01-29 09:15 李子哥哥      
很不错,支持楼主
 回复 引用 查看   
#54楼 2010-02-24 17:49 kingkit      
关注楼主很久了呵呵
能把东西做好并且能分享给人家,确实很厉害~~
支持一下了

 回复 引用 查看   
#55楼[楼主] 2010-03-01 15:38 cloudgamer      
@李子哥哥
@kingkit
谢谢支持!!

 回复 引用 查看   
#56楼 2010-03-19 11:37 treblam      
读你的博客能学到很多东西。
不过对其中一个bind方法有点疑问:
return fun.apply(thisp, args.concat(slice.call(arguments)));
后面这部分是否有点多余:.concat(slice.call(arguments)),我感觉return fun.apply(thisp, args)就够了啊。

 回复 引用 查看   
#57楼[楼主] 2010-03-19 13:57 cloudgamer      
@treblam
下面这个用法就会用到
var x = $$F.bind(function(x,y){return x+y},null,3)
alert(x(4))
alert(x(-4))

 回复 引用 查看   
#58楼 2010-03-20 12:33 treblam      
试了一下,的确如此,不过感觉功能是很强,但可读性好差。
 回复 引用 查看   
#59楼[楼主] 2010-03-20 13:39 cloudgamer      
@treblam
你有更好的方法?
也不是功能强不强
用到了就明白了

 回复 引用 查看   
#60楼 2010-03-20 15:35 treblam      
没有更好的方法,只是这种写法之前没接触过,读起来有点吃力。
 回复 引用 查看   
#61楼[楼主] 2010-03-20 16:11 cloudgamer      
@treblam

我也不是一下子就明白的
当我不需要这个功能的时候我也觉得是多余的
但当我真正用到的时候我就明白它的意义了

 回复 引用 查看   
#62楼 2010-03-22 17:31 soonco      
还是搞不清楚bind和bindAsEventListener的具体区别,能否详细讲解(希望有个对比的例子),很崇拜楼主~最近做东西扒了不少lz的代码,感觉很罪恶,还是想真正的把js这门语言弄清楚,所以lz所有的例子我都在一行一行的学习,希望赐教
 回复 引用 查看   
#63楼[楼主] 2010-03-22 19:09 cloudgamer      
@soonco
bindAsEventListener就是指定了第一个参数是event咯

 回复 引用   
#64楼 2010-04-02 08:51 科杰[未注册用户]
惭愧,第一次听说这个命名空间在这个库上。。悲
 回复 引用 查看   
#65楼[楼主] 2010-04-02 10:13 cloudgamer      
@科杰
这个命名空间在这个库上??

 回复 引用 查看   
#66楼 2010-04-22 13:58 惜缘      
您源码的操作DOM对象的rect函数中有这么一行注释.
“ie8的getBoundingClientRect获取不准确”
但我测试了一下。好像是IE7的有2px的差距,其它浏览器正确。
不知道是您一时疏忽,还是我解理的错误。
很谢谢你的代码开放。学到不少东西。
想和您交个朋友。QQ:14030525,如果您看到请加我,不盛感激。

 回复 引用 查看   
#67楼[楼主] 2010-04-22 14:26 cloudgamer      
@惜缘
可以看看这个测试
http://bbs.51js.com/thread-84992-1-1.html

 回复 引用 查看   
#68楼 2010-04-22 15:06 惜缘      
引用cloudgamer:
@惜缘
可以看看这个测试
http://bbs.51js.com/thread-84992-1-1.html

很高兴看到您的回复。我用的是360浏览器,他是IE7的内核,也许是360的原因。我在单位,不能上QQ,不知道您加我没:)。嘿嘿

 回复 引用 查看   
#69楼 2010-04-22 15:14 惜缘      
O.extend = function (destination, source) {
for (var property in source) {
if(!destination[property])//这样会不会好一点呢?
destination[property] = source[property];
}
return destination;
};

 回复 引用 查看   
#70楼[楼主] 2010-04-23 08:25 cloudgamer      
@惜缘
我也很少上q76511088
if(!destination[property])这样就不能覆盖属性值了

 回复 引用   
#71楼 2010-05-17 11:12 Ttttx[未注册用户]
楼主, 没看到你QQ上线过哦...
 回复 引用 查看   
#72楼[楼主] 2010-05-17 13:31 cloudgamer      
@Ttttx
有什么问题要问吗?

 回复 引用   
#73楼 2010-05-19 10:35 naiyi[未注册用户]
O.deepextend = function (destination, source) {
for (var property in source) {
var copy = source[property];
if ( destination === copy ) continue;
if ( typeof copy === "object" ){
destination[property] = arguments.callee( destination[property] || {}, copy );
}else{
destination[property] = copy;
}
}
return destination;
};

第四行 能解释一下吗?

 回复 引用 查看   
#74楼[楼主] 2010-05-19 11:23 cloudgamer      
@naiyi
如果要复制的对象是destination本身就跳出
否则会死循环

 回复 引用   
#75楼 2010-05-19 11:28 naiyi[未注册用户]
O.wrapper = function(me, parent) {
var ins = function() { me.apply(this, arguments); };
var subclass = function() {};
subclass.prototype = parent.prototype;
ins.prototype = new subclass;
return ins;
};

为什么要加subclass这个空的函数,直接ns.prototype = parent.prototype;不行吗? 能给个使用O.warpper的例子吗?

 回复 引用 查看   
#76楼[楼主] 2010-05-19 11:38 cloudgamer      
@naiyi
因为new时会执行一次subclass函数,空函数就是想什么都不执行,只用来继承prototype
这个就用到了wrapper
http://www.cnblogs.com/cloudgamer/archive/2010/03/03/ImagesLazyLoad.html

 回复 引用   
#77楼 2010-05-19 13:29 naiyi[未注册用户]
谢谢你的回答 第一个问题明白了,但是第二个问题还是有疑问,既然subclass只是起到传递prototype的作用,那么new subclass再赋给ins.prototype 只是在prototype链上增加了一个只有_pro_属性的空节点,这个_pro_属性指向parent.prototype,和直接ins.prototype = parent.prototype不是没有区别吗? new ins()也不会执行parent()的。我再看一下你给的例子,小弟还是js新手,还请多指教。
 回复 引用 查看   
#78楼[楼主] 2010-05-19 13:38 cloudgamer      
@naiyi
例如如果subclass里面有一个
this.a=1
那么就会给prototype加一个a属性了

 回复 引用   
#79楼 2010-06-23 17:20 naiyi[未注册用户]
var subclass = function() {};
subclass.prototype = parent.prototype;
ins.prototype = new subclass;
改成
ins.prototype = parent.prototype;
效果其实是一样的,
增加了这个subclass才有可能出现你说的这种把subclass属性a增加到ins.prototype的可能性。
这也不是本意吧,那为什么要增加这个subclass呢?
我看prototype也是这么写的,不理解。。。

 回复 引用   
#80楼 2010-06-23 21:28 naiyi[未注册用户]
终于想明白了。。。如果没有subclass这个对象,定义ins.prototype.method=function(){}的时候同时也给parent.prototype增加了method这个方法,是错误的。
 回复 引用 查看   
#81楼[楼主] 2010-06-28 00:30 cloudgamer      
@naiyi
是的

 回复 引用   
#82楼 2010-06-29 16:58 naiyi[未注册用户]
哈哈 还得跟你多学习啊! 我再使劲读读您的大作,看不懂的问您别嫌烦啊
 回复 引用 查看   
#83楼[楼主] 2010-06-30 10:04 cloudgamer      
@naiyi
欢迎讨论

 回复 引用   
#84楼 2010-07-07 11:37 nickcc[未注册用户]
好久没更新了呢
 回复 引用 查看   
#85楼[楼主] 2010-07-07 15:32 cloudgamer      
@nickcc
没办法
太忙了

 回复 引用 查看   
#86楼 2010-07-18 10:18 BlueDream      
cloud兄请教两个问题:
关于IE下的getStyle.
1. 关于转换成像素值.按照你和jQuery的curCss都是先用runtimeStyle做覆盖.
但其实不用runtimeStyle其实也是没问题的是吧? 因为一瞬间转换完毕.就又恢复成开始保存的left值了.

2.在淘宝的KISSY里提到IE下转换百分比单位的width,height时候.用pixelLeft转换的不对.而要用offsetWidth, offsetHeight取. 但我测试并没有不对. 不知道你有什么看法.

谢谢指教~

 回复 引用 查看   
#87楼 2010-07-19 17:32 无爱      
我对你的敬佩之情,都在帮你点击广告里了!
 回复 引用 查看   
#88楼[楼主] 2010-07-19 23:36 cloudgamer      
@无爱
谢谢支持

 回复 引用 查看   
#89楼[楼主] 2010-07-19 23:53 cloudgamer      
@BlueDream
1 有些机器比较慢就可能会看到 而且没有reflow效率应该会比较好
2 auto的时候是取不到至于百分比我也没测试 你知道也告诉我吧

 回复 引用   
#90楼 2010-07-20 15:38 thinksnet[未注册用户]
牛人,真的很强!
 回复 引用   
#91楼 2010-07-20 15:42 thinksnet[未注册用户]
请教楼主,CJL与mootoos在一起用是否会冲突?谢谢指教
 回复 引用   
#92楼 2010-07-20 15:43 thinksnet[未注册用户]
请教楼主,CJL与MooTools在一起用是否会冲突?谢谢指教,sorry上面那个打错了^_^
 回复 引用 查看   
#93楼[楼主] 2010-07-20 18:02 cloudgamer      
@thinksnet
我也没试过呢
反正这几个东西没冲突就行
$$ $$B $$A $$F $$D $$E $$CE $$S

 回复 引用   
#94楼 2010-07-21 13:31 thinksnet[未注册用户]
楼主,我试了一下"仿京东商城商品分类菜单"这个案例与MooTools在一起用可能是$$有冲突,我把$$改成了CJL后,除了ie6外,其它主流浏览器都可以用了,与MooTools在一起用ie6会提示错误,比如:缺少标识符、字符串或数字等错误,我也不知道为啥,也可能是与其它js有冲突
 回复 引用   
#95楼 2010-07-21 13:57 thinksnet[未注册用户]
楼主,ie6 js报错找到原因了,是因为引用js的文件编码与js文件编码不一致造成的,全部改成utf-8或gb2312就可以了,希望同仁们遇到此类问题注意一下编码要一致
 回复 引用 查看   
#96楼[楼主] 2010-07-21 14:02 cloudgamer      
@thinksnet
是的
我也遇过几次

 回复 引用 查看   
#97楼 2010-08-04 19:20 On My Way...      
谢谢LZ,不过我想问下,有没有帮助文档?
 回复 引用 查看   
#98楼[楼主] 2010-08-04 20:01 cloudgamer      
@On My Way...
这里有就文档了
有什么不明白的可以提出

 回复 引用 查看   
#99楼 2010-08-05 10:20 On My Way...      
我有一个关于DIV文本定时跳转的问题,在IE里面会出现重复的文本,其他浏览器不会。如果楼主有空的话,请加我Q:281709101。想请教一下。
 回复 引用 查看   
#100楼[楼主] 2010-08-05 10:54 cloudgamer      
@On My Way...
现在上不了q
可以把问题留言或email给我看看

 回复 引用 查看   
#101楼 2010-08-05 11:10 On My Way...      
引用cloudgamer:
@On My Way...
现在上不了q
可以把问题留言或email给我看看

先谢谢LZ了,昨晚上仔细检查了一下,好像是CSS有冲突,主要页面不是我设计的。我把外部CSS样式去掉之后就不会有重复了。我再看看吧,要不解决不了,还得请教一下您。 非常感谢

 回复 引用 查看   
#102楼 2010-08-05 11:40 On My Way...      
还是得请教LZ,我发消息给你了。
 回复 引用 查看   
#103楼[楼主] 2010-08-05 13:45 cloudgamer      
@On My Way...
你发的不完整

 回复 引用 查看   
#104楼 2010-08-05 13:50 ShawnZhang      
我在用到AJAX取值的时候发现不能跳转到后台,而等页面加载好了就能跳
这是为什么,希望帮帮我,QQ:390485243

 回复 引用 查看   
#105楼[楼主] 2010-08-05 16:49 cloudgamer      
@ShawnZhang
又AJAX又跳转到后台
没看明白

 回复 引用 查看   
#106楼 2010-08-05 17:16 On My Way...      
问题解决了,谢谢LZ,收徒弟不?呵呵。
什么时候谈下您的学习心得吧!

 回复 引用 查看   
#107楼[楼主] 2010-08-05 17:33 cloudgamer      
@On My Way...
我知道的都基本在这个博客里面了
呵呵

 回复 引用   
#108楼 2010-08-10 00:05 deepextend[未注册用户]
if (destination === copy) continue;
深度复制的这句据说是为了防止死循环. 但我注释掉以后.试了几个测试用例都没出现死循环.楼主可否给个测试用例?

 回复 引用 查看   
#109楼[楼主] 2010-08-10 01:00 cloudgamer      
@deepextend
你要实现destination === copy的情况啊

 回复 引用 查看   
#110楼 2010-08-14 22:01 ifree      
我想关注你,但是找不到在哪关注就来留言了
 回复 引用 查看   
#111楼 2010-08-18 17:17 joyan      
我学习javascript效率好低啊,一年时间远远达不到你的水平,也想听听你的学习心得
 回复 引用 查看   
#112楼 2010-08-30 15:55 web-js      
跟随 博主学习
 回复 引用 查看   
#113楼[楼主] 2010-09-05 17:25 cloudgamer      
@ifree
@joyan
@web-js
谢谢支持

 回复 引用 查看   
#114楼 2010-11-17 14:37 hello_js      
楼主真好,谢谢了!
 回复 引用   
#115楼 2010-11-23 16:32 珍衢安儿[未注册用户]
博主好强,跟着博主学知识。。
 回复 引用 查看   
#116楼[楼主] 2010-11-23 17:33 cloudgamer      
@hello_js
@珍衢安儿
谢谢支持

 回复 引用   
#117楼 2011-01-01 08:47 huaidong[未注册用户]
博主元旦快乐!
 回复 引用   
#118楼 2011-01-19 01:41 konghulu[未注册用户]
受益匪浅。
 回复 引用   
#119楼 2011-01-20 10:59 _vai[未注册用户]
哎,确实得实现自己的轻量级的JS框架,由于引入了PROTOTYPE,JQUERY等等框架,而且由于控件也可以下现成的,也有很多直接集成到了PHP的一些开源项目,结果导致前端的JS及其臃肿了,而且无法对JS的加载周期进行流程性的控制,结果页面光读取JS都要一秒多钟,LZ这样其实很好,高手!!!学习了!!!
 回复 引用 查看   
#120楼[楼主] 2011-01-20 11:49 cloudgamer      
@huaidong
@konghulu
@_vai
谢谢支持

 回复 引用 查看   
#121楼 2011-02-07 07:04 1819.tv-xie      
写的很不错,学到不少,收益良多,谢谢!
 回复 引用   
#122楼 2011-02-09 11:18 huaidong[未注册用户]
新年快乐!
 回复 引用 查看   
#123楼 2011-05-25 11:26 bin jie      
AlertBox.js $$B is not defined 79

知者请马上告诉我吧,我急用呀

 回复 引用 查看   
#124楼[楼主] 2011-05-26 21:31 cloudgamer      
@1819.tv-xie
@huaidong
谢谢支持

 回复 引用 查看   
#125楼[楼主] 2011-05-26 21:31 cloudgamer      
@bin jie
自己调试吧

 回复 引用 查看   
#126楼 2011-06-05 20:15 only sea      
O.wrapper = function(me, parent) {
var ins = function() { me.apply(this, arguments); };
var subclass = function() {};
subclass.prototype = parent.prototype;
ins.prototype = new subclass;
return ins;
};

您好,您的这部分代码我觉得会出现constructor紊乱的问题。参考了ext-base,觉得
O.wrapper = function(me, parent) {
var ins = function() { me.apply(this, arguments); };
var subclass = function() {},
sbp;
subclass.prototype = parent.prototype;
sbp=ins.prototype = new subclass;
sbp.constructor=me;
return ins;
};
是否更好呢?
入行不久的新手,若为谬论还望海涵

 回复 引用 查看   
#127楼[楼主] 2011-06-06 09:24 cloudgamer      
@only sea
我没用过constructor所以没问题
如果你需要的话要加上

 回复 引用 查看   
#128楼 2011-06-06 18:56 only sea      
*-*
 回复 引用   
#129楼 2011-06-12 08:47 www.cnnat.com[未注册用户]
写的还真不错
 回复 引用 查看   
#130楼 2011-07-12 10:58 浅水鱼      
好文 支持,来到的太晚了...
 回复 引用 查看   
#131楼[楼主] 2011-07-13 07:55 cloudgamer      
@only sea
@www.cnnat.com
@浅水鱼
谢谢支持

 回复 引用 查看   
#132楼 2011-08-10 08:32 water_down      
D.getScrollLeft 中return doc.documentElement.scrollLeft||doc.body.scrollLeft;
在ie下报错....

 回复 引用   
#133楼 2011-08-19 14:37 edawf[未注册用户]
是陆地恢复华盛顿费口舌拉夫
 回复 引用   
#134楼 2011-08-19 15:25 doc2003[未注册用户]
实例我在html中试过,没问题,果然很强大
但我弄到JFS中时,总是提示"[错误]javax.servlet.ServletException: null source",我将空间都改成了JSF模式下的控件了,<script>里面的代码,看不出要改哪里。请问要修改什么地方吗?

 回复 引用   
#135楼 2011-08-31 17:26 asi[未注册用户]
楼主:
不错!
但是我发现你的CE,有些小问题:
例如我addEvent两次同一个handle,但是只相应一个。可以模拟domlevel2 中返回一个值,用于唯一确定此消息相应,

 回复 引用 查看   
#136楼 2011-10-07 13:46 幸福调品牌设计      
不错,谢谢分享
www.xingfudiao.com
专业网站美工

 回复 引用   
#137楼 2011-10-19 15:36 webmm[未注册用户]
来晚了,佩服!!
 回复 引用   
#138楼 2011-11-07 15:21 33344rr[未注册用户]
引用doc2003:
实例我在html中试过>里面的代码,看不出要改哪里。请问要修改什么地方吗?

sdfdsfds

 回复 引用   
#139楼 2011-11-07 15:21 33344rr[未注册用户]
vcccc
 回复 引用 查看   
#140楼 2011-11-15 00:40 bird1986      
        forEach: function( object, callback, thisp ){
            each( object, function(){ callback.apply(thisp, arguments); } );
        },


你好,想请问下这里加上thisp进行apply,是否为了可以类似这样的情形。
			var a = {1:1, 2:2, 3:3};
			$$A.forEach(a, function(obj, i, objs){
				this[i] = this[i] + 1;
			}, a);
			console.log(a);

可以使用this进行计算?

 回复 引用 查看   
#141楼 2011-12-05 23:05 guiren      
***
 回复 引用 查看   
#142楼 2011-12-06 10:34 cyndy_li      
你好,我想请教个问题,我是新手,知之甚少,我想问ajax在你的库里,怎样用,比如jquery用$post方法,在这里用什么,是$$post么,还是什么,期待你的回复。
评论共2页: 上一页 1 2 
发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 1591815 s7tquKOSe04=