关于javascript中的this 一段小实例深有体会啊
先声明鄙人正在努力的把脚抬进门来,说的都是比较粗浅的知识,但都是我实践中得出的体会,很深刻。 正在自学中挣扎的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 一段小实例深有体会啊的更多相关文章
- 【前端】javascript中10常用的个小技巧总结
javascript中10常用的个小技巧总结 本文转自:http://www.cnblogs.com/libin-1/p/6756393.html 1. new Set() 可能有人知道ES6中提供了 ...
- JavaScript中字符串分割函数split用法实例
这篇文章主要介绍了JavaScript中字符串分割函数split用法,实例分析了javascript中split函数操作字符串的技巧,非常具有实用价值,需要的朋友可以参考下 本文实例讲述了JavaSc ...
- Javascript中Base64编码解码的使用实例
Javascript为我们提供了一个简单的方法来实现字符串的Base64编码和解码,分别是window.btoa()函数和window.atob()函数. 1 var encodedStr = win ...
- JavaScript中的 原型 property 构造函数 和实例对象之间的关系
1 为什么要使用原型? /* * javascript当中 原型 prototype 对象 * * */ //首先引入 prototype的意义,为什么要使用这个对象 //先来写一个构造函数的面向对象 ...
- Javascript中window.opener的一点小总结
以前一直认为window.opener只有在window.open方法打开下的窗口才可以访问,没想到即使是a链接打开的页面的照样可以访问.window.opener指向父窗口,也就是来源窗口.可以利用 ...
- 一些JavaScript中的DOM的优化小技巧
在进行DOM优化时需要关注的问题有:修改DOM的时候,会引起页面的重排,重绘.因为JS是单线程执行的,那么在重排重绘的过程中可能会阻塞用户的操作.为了更好的用户体验,必须要严格控制这些操作. 一.对象 ...
- javascript中关于value的一个小知识点(value既是属性也是变量)
今天在学习input的value值时,发现这么一个小知识点,以前理解不太透彻 [1]以下这种情况是常见情况,会弹出“测试内容” <input type="button" va ...
- javascript中关于&& 和 || 表达式的小技巧分享
如果你还是新手, 而且读完所有这些技巧的详解和每种技巧是如果工作的以后运用它们, 你会写出更加简练高效的JavaScript程序. 确实, JavaScript高手已经运用这些技巧写出了很多强大, 高 ...
- JavaScript中的setMonth()方法的小问题 解决:setMonth(month, 1)
今天测试人员发现一个问题,从英文日期转化中文日期,月份总会有“6月”变为“7月”.于是我在本地反复测试,发现如下规律:只要setMonth()的参数为小于31天的月份时就会变为下一个月. 原因是:因为 ...
随机推荐
- 各种数据库分页语句整理以及Oracle数据库中的ROWNUM和ORDER BY的区别
.oracle数据库分页 select * from (select a.*,rownum rc from 表名 where rownum<=endrow) a where a.rc>=s ...
- [bzoj5158][Tjoi2014]Alice and Bob
好羞愧啊最近一直在刷水... 题意:给定序列$c$的$a_i$,构造出一个序列$c$使得$\sum b_i$最大. 其中$a_i$表示以$c_i$结尾的最长上升子序列长度,$b_i$表示以$c_i$为 ...
- 2007: [Noi2010]海拔
2007: [Noi2010]海拔 https://www.lydsy.com/JudgeOnline/problem.php?id=2007 分析: 平面图最小割. S在左下,T在右上,从S到T的一 ...
- Java:详解内部类
可以将一个类的定义放在另一个类的定义内部,这就是内部类. 内部类是一个非常有用的特性但又比较难理解使用的特性(鄙人到现在都没有怎么使用过内部类,对内部类也只是略知一二). 第一次见面 内部类我们从外面 ...
- ORB-SLAM (四)tracking单目初始化
单目初始化以及通过三角化恢复出地图点 单目的初始化有专门的初始化器,只有连续的两帧特征点均>100个才能够成功构建初始化器. ); 若成功获取满足特征点匹配条件的连续两帧,并行计算分解基础矩阵和 ...
- cachel-control
nodejs: res.set('Cache-Control', 'public, max-age=31557600'); express全局设置: app.use(express.sta ...
- jmeter无法启动的解决办法
jmeter下载地址: 链接: https://pan.baidu.com/s/15YhiPH-kNVxISEZ4Mxf_WA 提取码: 25sv jdk 8.0 下载地址: 链接: http ...
- 大批量复制Oracle数据表,连带复制主键约束,字段说明以及字段默认值(量产)
DECLARE CURSOR tab_name_cur IS SELECT table_name FROM user_tables ...
- you need to resolve your current index first 已解决
从一个分支A切换到另一个分支B后,对切换后的B分支进行pull操作,因为pull操作实际上包含了fetch+merge操作,在执行 merge操作时,由于很长时间没有对B分支执行过pull/merge ...
- 【Linux运维】LNMP环境配置
安装准备: Centos7.3 MYSQL5.6 PHP5.6 NGINX1.10.3 一.安装Mysql mysql:[root@host129 src]#cd /usr/local/src/ [r ...