位置: 编程技术 - 正文

JS常见问题之为什么点击弹出的i总是最后一个(javascript常见问题)

编辑:rootadmin

推荐整理分享JS常见问题之为什么点击弹出的i总是最后一个(javascript常见问题),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript常见问题,js中遇到的问题,javascript常见问题,js中出现nan解决方案,javascript:;怎么解决,js常见错误,js常见错误,js中遇到的问题,内容如对您有帮助,希望把文章链接给更多的朋友!

在前端群里看见过很多人问过这个问题,今晚又有人问了这个问题,所以写篇文章整理一下。首先看一下代码,点击li之后弹出当前li所对应的索引值。于是很多人刷刷刷写出了下面的代码。

但是结果不尽人意,为了简单,我们约定一下页面中有2个li。点击li之后弹出的都是2。 我们首先来分析一下为什么结果是1.我们可以简单的将循环分成两部。

在执行click的函数的时候,会有一个作用域链,这个作用域链是一个对象列表,这组对象定义了代码作用域中的变量。( 关于变量对象的内容想更详细了解的可以查看变量对象。)当我们alert(i)的时候,会去从内到外的去寻找变量i。这个时候这个函数的作用域链上有两个对象,这时循环已经结束了,i此时的值为2.所以点击任何一个li,弹出的都是2,而不是我们想要的索引值。重点在于弹出的是变量i,变量i,变量i。重要的事情说三遍。

那么问题来了,我们要如何解决这个问题呢。我们需要做的就是在每次给aLi[i]绑定事件的时候,将这个时候i的值保存在内部的作用域中。解决方案如下。

这里涉及到一个块级作用域的概念。在es6出来前,函数是作为创建块级作用域的主要手段。这里我们通过在aLi[i].onclick外面套上一层函数,将i作为参数,我们重新分析一下结果。

由于多了一层自执行函数的包裹,当我们点击li时,会有三层的作用域,从内带外分别是:click函数内部的变量对象,自执行函数的变量对象和最外层的window对象。查找到第二层的时候,找到了i,自执行函数的i等于传入的参数值,相对应的存下了当时i的值,所以就弹出了相应的索引值。

下面再给大家分享一个js常见的问题,实现点击li能够弹出当前li索引与innerHTML的函数

JS常见问题之为什么点击弹出的i总是最后一个(javascript常见问题)

点击其中一项需要alert出如下结果:

按照我们平常的想法,代码应该是这样写的:

但是不巧的是产生的结果是这样的:

索引index为什么总是4呢,这是js中没有块级作用域导致的。这里有三种解决思路

1. 使用闭包

2.使用ES6中的新特性let来声明变量

用let来声明的变量将具有块级作用域,很明显可以达到要求,不过需要注意的是得加个'use strict'(使用严格模式)才会生效

3.引入jquery,使用其中的on或delegate进行事件绑定(它们都有事件代理的特性)

JavaScript类型系统之正则表达式 定义正则又叫规则或模式,是一个强大的字符串匹配工具。javascript通过RegExp类型来支持正则表达式特性[1]贪婪性,匹配最长的[2]懒惰性,不设置/g,则

js与jQuery实现checkbox复选框全选/全不选的方法 本文实例讲述了js与jQuery实现checkbox复选框全选/全不选的方法。分享给大家供大家参考,具体如下:先来看看JavaScript实现checkbox复选框全选/全不选的方

javascript简单比较日期大小的方法 本文实例讲述了javascript简单比较日期大小的方法。分享给大家供大家参考,具体如下://获取起始日期varstartDate=document.all.startdate.value;//转换为日期格式

标签: javascript常见问题

本文链接地址:https://www.jiuchutong.com/biancheng/384707.html 转载请保留说明!

上一篇:浅谈javascript 函数表达式和函数声明的区别(javascript中的函数该如何理解)

下一篇:JavaScript类型系统之正则表达式(js的类型有哪几种)

  • 企业所得税工会经费调整
  • 资产处置出售
  • 所得税税前扣除凭证管理办法
  • 小微企业免税销售额是按1%还是3%
  • 车船税和保险在一起怎么报销
  • 养老保险滞纳金最高限额规定
  • 免交的附加税需要计提吗
  • 超市卡发票可以抵扣吗
  • 待报解预算收入计入什么科目
  • 收到股权回购款是什么意思
  • 二手房怎么避免一房多卖
  • 房地产开发企业预缴增值税
  • 付款单是发票吗
  • 盈利能力分析对企业发展的意义
  • 对公受托理财赎回分录
  • 冲回资产减值准备
  • 小规模纳税人提供设计服务税率
  • 赔偿金要交增值税吗
  • 网上认证增值税专用发票步骤图解
  • 增值税发票每个月什么时候可以开
  • 理财收益的增值怎么算
  • 贷款逾期了利息和罚息可以不还吗
  • 成本核算的意义是什么
  • 销售送礼品
  • 广告公司物料报价清单
  • 贷款发生减值
  • 存放中央银行款项科目按其资金性质
  • 企业之间是什么意思
  • php缓存文件并自动清理
  • 房屋出租房产税如何计算
  • 工商年报的社保缴费基数怎么算
  • php生成随机字符串
  • 云原生是什么
  • vuecli项目实战
  • 数学建模心态崩了
  • 防抖节流实现原理
  • ssh-keygen命令
  • 从univ.txt文件中去掉机构名称
  • 软件开发行业税负
  • 兼职人员需要
  • 生产企业支付的车间劳务外包费入账科目
  • 小企业的流动资产
  • 工资计提与发放在一个月行吗
  • 私对公可以转账吗?会对做账不利吗
  • python condition
  • 企业应缴纳税款
  • 待处理流动资产损失属于什么科目
  • 对股息红利的征税
  • 财务报表没报会影响出口退税吗为什么
  • 土地增值税中开发间接费用工资包括哪些人
  • 管理费用算营业外支出吗
  • 机械设备预付款比例
  • 购进生产免税货物用材料可以抵扣进项税额吗
  • 转账错误退款说明
  • 水利建设行业
  • 开具红字发票后所冲销的销项税应该怎么处理?
  • 小企业固定资产折旧方法
  • 房屋建筑物固定资产标牌图片
  • 转账支票遗失声明
  • 代理赚差价违法吗
  • 健身房健身器材采购清单
  • 什么是利润表?其作用有哪些?
  • 增值税为负值时当年可抵扣的进项税
  • 小型便利店靠什么进行营利
  • 材料报废 开什么发票
  • 简单基是什么
  • centos apache 配置
  • xp系统网络设置在哪
  • 电脑上dell是什么意思
  • win7电脑能登qq但打不开网页怎么办
  • PACKAGER.EXE - PACKAGER是什么进程 有什么用
  • qt配置opengl
  • Node.js中的什么模块是用于处理文件和目录的
  • linux查看内存型号与数量
  • node调试工具
  • android全局异常捕获并弹框提示
  • xml-js
  • Javascript字符串对象函数
  • 四川税务专管员查询
  • 安徽省建筑企业资质查询
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设