下面这段代码是常用的网站首页,自动切换span或者tabbar来变更List显示内容的关键方法:function scrollDoor(){}scrollDoor.prototype = {sd : function(menus,divs,openClass,closeClass){var _this = this; //大家看清楚了,在这里,为什么不直接用this,要用_this代替后面的所有this,这有什么特殊的意义吗?如果用了this会怎么样?一共2个问题哈!if(menus.length != divs.length){alert("菜单层数量和内容层数量不一样!");return false;}for(var i = 0 ; i < menus.length ; i++){_this.$(menus[i]).value = i;_this.$(menus[i]).onmouseover = function(){for(var j = 0 ; j < menus.length ; j++){_this.$(menus[j]).className = closeClass;_this.$(divs[j]).style.display = "none";}_this.$(menus[this.value]).className = openClass;_this.$(divs[this.value]).style.display = "block";}}},$ : function(oid){if(typeof(oid) == "string")return document.getElementById(oid);return oid;}}
2 回答
千巷猫影
TA贡献1829条经验 获得超7个赞
问题一:
不知道楼主有没有接触过jquery jquery里边有一个特别典型的例子能说明用_this的作用
$("#btn").click(function(){
var _this = this;//这里this和_this都代表了"#btn"这个对象
$(".tr").each(function(){
this;//在这里this代表的是每个遍历到的".tr"对象
_this;//仍代表"#btn"对象
})
})
这种情况就是在一个代码片段里this有可能代表不同的对象,而编码者希望_this代表最初的对象
问题2:
其实并没有全部使用_this
但是据我所看,应该没有任何区别的,楼主的代码里用_this可能只是为了编码规范吧
添加回答
举报
0/150
提交
取消