子洋丶 2021-03-25 16:06 采纳率: 100%
浏览 55
已采纳

Jquery on 绑定事件后,点击事件存在问题

背景

这是在项目上遇到的一个问题,我在这里做了个简单的 Demo将问题复现,可以复制下来直接打开测试。

问题:

jq 通过  on 绑定点击事件,在事件中获取值插入到该元素,所有触发过点击事件的元素都会重复触发,导致数据会同时改变。

图例:

如下图,我先点击第一个框,插入值 aaaa

又新建一个一个框,插入bbbb,第一个框也会被同时修改。

测试:

本来一开始,我认为是元素获取不准确,但后来测试发现不是

在通过点击事件监听了一下触发次数发现,他会依次触发之前触发过的元素

下面就是问题代码,jq用的CDN,可以直接拿来运行 

<!DOCTYPE html>
<html>
<head>
	<title></title>
	<script type="text/javascript" src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
	<style type="text/css">
		.style{
			width: 300px;
			height: 50px;
			border: 1px solid red;
		}
		#add{
			width:40px;
			height: 40px;
			border:1px solid green;
			border-radius: 20px;
			text-align: center;
			line-height: 40px;
			position: absolute;	
			top:10px;
			left:350px;
		}
	</style>
</head>
<body>
	<div id="test">
		<div>
			<ul>
				<li class="style"></li>
			</ul>
		</div>
	</div>
	<div id="add">添加</div>
	<div id="list" >
		<ul>
			<li>aaaaaa</li>
			<li>bbbbbb</li>
			<li>cccccc</li>
			<li>dddddd</li>
			<li>eeeeee</li>
			<li>ffffff</li>
		</ul>
	</div>

	<script type="text/javascript">
		const ele = '<li class="style"></li>'

		$('#test').on('click','li',function(){
			const _this = this;

			let id = 1;
			$('#list > ul > li').click(function(){
				console.log(id++);
				$(_this).text($(this).text());
			});

			console.log('-----------------');
		});

		$('#add').click(function(){
			$('#test > div > ul').append(ele)
		})
	</script>
</body>
</html>

求教!!!

  • 写回答

2条回答 默认 最新

  • 暖光_& 2021-03-25 16:27
    关注

    <script type="text/javascript">
                const ele = '<li class="style"></li>'
                var _this = null;
                $('#test').on('click', 'li', function() {
                    _this = this;
                    console.log('-----------------');
                });

                $('#list > ul > li').click(function() {                
                    _this && $(_this).text($(this).text());        
                });

                $('#add').click(function() {
                    $('#test > div > ul').append(ele)
                })
            </script>

    不知道你要的是不是这个效果,你看看是不是这样

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥30 求给定范围的全体素数p的(p-2)的连乘积
  • ¥15 VFP如何使用阿里TTS实现文字转语音?
  • ¥100 需要跳转番茄畅听app的adb命令
  • ¥50 寻找一位有逆向游戏盾sdk 应用程序经验的技术
  • ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
  • ¥50 opencv4nodejs 如何安装
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页