先声明鄙人正在努力的把脚抬进门来,说的都是比较粗浅的知识,但都是我实践中得出的体会,很深刻。  正在自学中挣扎的DOG。

先看段代码:

function highlightRows() {
if(!document.getElementsByTagName) return false;
var tables = document.getElementsByTagName("table");
for(var i=;i<tables.length;i++){
var rows = tables[i].getElementsByTagName("tr");
for(var j =;j<rows.length;j++){
rows[j].onmouseover=function(){
//rows[j].style.fontWeight="bold"; //这样无效
this.style.fontWeight="bold";
}
rows[j].onmouseout=function() {
//rows[j].style.fontWeight="normal"; //这样无效
this.style.fontWeight="normal";
}
}
}
} //效果是为了鼠标放上去的时候 字体变粗。

说说我最开始的思维是怎么样的:就下面这段代码而言我以为上面的rows[j]和下面的row[j]  完全一样   j=0的时候就是指第一个tr  那么下面就是第一个tr实现

font-weight:bold;的效果了咯。打开网页什么都没有,还是和之前一模一样,查bug查半天也没有所以然,算了,照着书上把row[j]替换成this吧,再打开网页,

一放上去在就变粗了,但还是不明白为什么。so    书上做个标记:什么时候用this?this到底是什么? 说明我还是想知道为什么是this就可以(ps:之前了解了点点

this 指调用包含this这个函数的对象,白话就是:那个对象调用包含this的这个函数,那么this就指谁  或者说this是值调用他的对象)。

.................................................................................................................................................................................................

for(var j =0;j<rows.length;j++){
rows[j].onmouseover=function(){
//rows[j].style.fontWeight="bold"; //这样无效
this.style.fontWeight="bold";
}

之后网上查了一通,但都没有解决我这个问题,虽然我从中get了很多新的知识,终有一天貌似看到了一样的疑问,看了下别人的评论,貌似也不是很懂错在哪里了,

也不知道为什么突然就觉得自己之前的理解是错误的,按着新的理解去走一遍,end 大呼自己好蠢,真的是蠢,不过也没办法,走进了那个坑里就不会那么轻易的爬出来。

以下是新的理解:在代码执行到for循环的时候,for循环依次把这个循环体解析出来了。与此同时我们并没有去触发onmouseover事件,那么后面的rows[j]并没有变,j还是一个变量,相应的后面的rows[j] 并没有像我们所想的那么与前面相同。只有等我们触发onmouseover的时候这个函数才会触发,这个变量j才会去找他的值是多少。

如下;

rows[0].onmouseover=function(){
rows[j].style.fontWeight="bold"; }
rows[0].onmouseout=function() {
rows[j].style.fontWeight="normal"; }
rows[1].onmouseover=function(){
rows[j].style.fontWeight="bold"; }
rows[1].onmouseout=function() {
rows[j].style.fontWeight="normal"; }
.............//依次下去 假设tr有9个 那么执行到j=9的时候就不会执行了 此时在函数体中 j=9!

看到现在应该知道j的值是9,由此可见不是与前面的rows[j]想对应。而且我们并没有rows[9]这个tr。而this很好的解决了我们的问题  他是指调用他的对象(简单的理解,虽不严谨),那么就是指tr。

都是很基础的东西,但对像我这样当时迷惑了的同学肯定有所帮助。 当彻底搞明白了这个为什么之后,收获的却是很多很多。共勉!(如有错处,还望指正批评)

关于javascript中的this 一段小实例深有体会啊的更多相关文章

  1. 【前端】javascript中10常用的个小技巧总结

    javascript中10常用的个小技巧总结 本文转自:http://www.cnblogs.com/libin-1/p/6756393.html 1. new Set() 可能有人知道ES6中提供了 ...

  2. JavaScript中字符串分割函数split用法实例

    这篇文章主要介绍了JavaScript中字符串分割函数split用法,实例分析了javascript中split函数操作字符串的技巧,非常具有实用价值,需要的朋友可以参考下 本文实例讲述了JavaSc ...

  3. Javascript中Base64编码解码的使用实例

    Javascript为我们提供了一个简单的方法来实现字符串的Base64编码和解码,分别是window.btoa()函数和window.atob()函数. 1 var encodedStr = win ...

  4. JavaScript中的 原型 property 构造函数 和实例对象之间的关系

    1 为什么要使用原型? /* * javascript当中 原型 prototype 对象 * * */ //首先引入 prototype的意义,为什么要使用这个对象 //先来写一个构造函数的面向对象 ...

  5. Javascript中window.opener的一点小总结

    以前一直认为window.opener只有在window.open方法打开下的窗口才可以访问,没想到即使是a链接打开的页面的照样可以访问.window.opener指向父窗口,也就是来源窗口.可以利用 ...

  6. 一些JavaScript中的DOM的优化小技巧

    在进行DOM优化时需要关注的问题有:修改DOM的时候,会引起页面的重排,重绘.因为JS是单线程执行的,那么在重排重绘的过程中可能会阻塞用户的操作.为了更好的用户体验,必须要严格控制这些操作. 一.对象 ...

  7. javascript中关于value的一个小知识点(value既是属性也是变量)

    今天在学习input的value值时,发现这么一个小知识点,以前理解不太透彻 [1]以下这种情况是常见情况,会弹出“测试内容” <input type="button" va ...

  8. javascript中关于&& 和 || 表达式的小技巧分享

    如果你还是新手, 而且读完所有这些技巧的详解和每种技巧是如果工作的以后运用它们, 你会写出更加简练高效的JavaScript程序. 确实, JavaScript高手已经运用这些技巧写出了很多强大, 高 ...

  9. JavaScript中的setMonth()方法的小问题 解决:setMonth(month, 1)

    今天测试人员发现一个问题,从英文日期转化中文日期,月份总会有“6月”变为“7月”.于是我在本地反复测试,发现如下规律:只要setMonth()的参数为小于31天的月份时就会变为下一个月. 原因是:因为 ...

随机推荐

  1. Java基础——内部类

    一.什么是内部类 将一个类定义在另一个类里面或者一个方法里面,这样的类称为内部类 内部类所在的类在编译成功后,会出现这样两个class文件:OuterClass.class和OuterClass$In ...

  2. 教你如何更改xshell中的转发规则

    使用不同的类型转发,与之对应的端口,所以如果想要使用不同类型的转发就要更改端口使其与之一一对应.本集xshell专栏文章将为大家讲解如何更改转发规则. 更改转发规则操作如下: 1.打开会话对话框. 2 ...

  3. hdu1233 继续畅通工程 (最小生成树——并查集)

    还是畅通工程 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  4. 用 Qt 控制 Nikon 显微镜的电动物镜转盘

    用 Qt 控制 Nikon 显微镜的电动物镜转盘 最近的一个项目,用到了一台 Nikon 的金相显微镜,并且配了个电动的物镜转盘.为了控制这个电动物镜转盘,我折腾了差不多有4-5天.中间遇到了各种问题 ...

  5. Scala学习笔记(二):运行脚本文件

    在某个目录(如:F:\)下新建一个文本文件,命名为:hello.scala 其内容为: println("Hello World!") 那么这个时候该怎么运行这个脚本文件呢? 通过 ...

  6. Git初步

    在多人参与开发的项目中,版本控制工具是必须的,网上有很多不错的教程,能简单使用就ok了,粘几篇教程,方便学习 首先我们要了解一些基本的概念,此处简单描述一下 (1)集中式版本控制系统: CVS.SVN ...

  7. spring boot 连接mysql 错误The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one

    1.spring boot 整合mybatis 连接mysql时错误 The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or repr ...

  8. 虚拟现实-VR-UE4-编辑自定义Character-上下左右移动-旋转

    在上一片文章中,我创建了一个自定义的Character,但是只是有一行log显示,我使用了自己的Character,不能有任何操作,这里,我将记录我修改我的Character的过程 万事第一步,打开工 ...

  9. 游戏测试中遇到的奇葩bug(不断整理中...)

    1:跨服组织战中,不同服务器相同组织ID的敌对玩家不能造成伤害. 2:节日活动24点开启,角色不下线自然过渡到活动开启,界面显示异常 3:前端请求数据之后,不管是否接收到后端返回的数据,只要玩家点击仙 ...

  10. IDEA + Maven + SSM 框架整合步骤

    因为前段时间自己想写个SSM的demo,然而不知怎么回事,配置完之后出现错误,怎么都调不好.最后从朋友那里拷了一个SSM的demo过来搭建成功,写这篇东西也是为了以后如果还有需要可以方便的查阅,并且也 ...