Js子函数怎么访问外部变量
发表于:2025-01-17 作者:千家信息网编辑
千家信息网最后更新 2025年01月17日,今天小编给大家分享一下Js子函数怎么访问外部变量的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了
千家信息网最后更新 2025年01月17日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安全错误
数据库的锁怎样保障安全
成人学软件开发
tcp测试服务器
护苗网络安全教育课课件
甘肃金融系统网络安全竞赛
软件开发赚美元
科创板网络安全行业
网络安全书怎么写
网络安全检查自查方案模板
数据库中视图的性质
淘宝买家数据库
网络安全通知模板
医用有限元软件开发招聘广州
服务器虚拟机安装详细教程
石家庄软件开发外包服务
河南服务器电源种类
软件开发行业人员工资
服务器内网ip地址
金山文档链接服务器异常
java服务器运行环境
电子支付与网络安全试卷
成都中扬网络技术有限公司
现代病数据库
等级制转换数据库语言
培养网络安全教育
自己电脑做服务器数据库
软件开发节点图
数据库监控怎么用
邵东中工互联网科技有限公司
十堰第五空间网络安全
国产数据库技术学院