Js子函数怎么访问外部变量
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,今天小编给大家分享一下Js子函数怎么访问外部变量的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了
千家信息网最后更新 2025年11月07日Js子函数怎么访问外部变量
今天小编给大家分享一下Js子函数怎么访问外部变量的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
Js 子函数如何访问外部变量?分享三种解决方案。我们在写 web 页面时,肯定会经常遇到下面这种情况:
代码很简单,就是在页面上创建几个按钮,同时定义按钮的点击事件

可当点击按钮时,我们发现获取到的序号一直都是5,也就是 i 最后的值。
这是因为定义click事件时的匿名函数所引用的都是同一个变量 i
解决办法1:立即执行
var wrapper = $('.btns-wrapper');for(var i = 0; i < 5; i++){var btn = $('').appendTo(wrapper); //默认方法//btn.on('click', function(evt){// console.log('点击按钮:' + i);//}); //方法1:立即执行btn.on('click', (function(n){return function(evt){console.log('点击按钮:' + n);}})(i)); }这种方式就是在定义事件时直接为每个按钮都创建了一个独立的匿名函数(闭包),并且每个函数都持有正确的 i 变量
解决办法2:利用jquery的事件传参
var wrapper = $('.btns-wrapper');for(var i = 0; i < 5; i++){var btn = $('').appendTo(wrapper); //默认方法//btn.on('click', function(evt){// console.log('点击按钮:' + i);//}); //方法2:利用JQuery的事件传参btn.on('click', { i: i }, function(evt){console.log('点击按钮:' + evt.data.i);}); }这种办法就简单多了,直接利用jquery将参数体传递给匿名函数即可。
解决办法3:利用dom的data属性
var wrapper = $('.btns-wrapper');for(var i = 0; i < 5; i++){var btn = $('').appendTo(wrapper); //默认方法//btn.on('click', function(evt){// console.log('点击按钮:' + i);//}); //方法3:利用dom的data属性btn.data('i', i);btn.on('click', function(evt){console.log('点击按钮:' + $(this).data('i'));}); }这种方法也很简单,弊端就是无法利用data属性定义结构化的数据。
以上就是"Js子函数怎么访问外部变量"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。
按钮
函数
方法
变量
事件
办法
就是
知识
篇文章
属性
内容
页面
不同
很大
也就是
代码
参数
同时
大部分
序号
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
低价软件开发首选
数据库sa密码改了后
观察者模式 数据库
滨江学院数据库技术及应用
演讲稿六年级网络安全
航空公司软件开发需求
中电15所软件开发
还原数据库执行一直0%
南沙区软件开发报名
计算机网络技术学3d建模吗
如何在数据库查表名
猫头鹰 网络安全
南通棋牌软件开发
网络安全法 部门负责
电子软件开发有限公司
网络安全法 收集
网络安全方面企业排行
数据库管理系统有哪些
阿里云服务器负载均衡搭建
python3格式化数据库
新乡市嘉元网络技术有限公司
西安公安局网络安全
抖音充值说苹果服务器异常
投标软件开发合理化建议
建筑服务器怎么样
陕西省中学生网络安全教育
长沙app软件开发有用吗
天津大学网络安全专业
银行软件开发薪资水平 济南
隐藏网络安全性