课堂笔记——查找替换

本文介绍了一个常见的JavaScript加载位置导致的问题:当JS文件放置在HTML头部并尝试绑定元素上的onclick事件时,由于DOM元素尚未加载完成而引发错误。文章提供了解决方案,即通过将JS文件置于HTML底部来确保DOM元素被正确加载。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
	<style>
		p{
		border:10px solid #ccc;
		background:#FFC;
		width:400px;
		padding:20px;
		font-size:16px;
		font-family:微软雅黑;

	}
		span1{
			background-color:#FF0000;
		}
		</style>
</head>

<body>
	<input type="text"/>
	<input type="button" value="查找">
	<input type="text"/>
	<input type="button" value="替换">
	<p>当js文件放在head里面时,如果绑定了onclick事件,就会出现这样的错误,是因为W3School的写法是浏览器先加载完按钮节点才执行的js,所以当浏览器自顶向下解析时,找不到onclick绑定的按钮节点,于是报错。因此,需要把js文件放在底部加载,就会避免该问题。</p>
</body>
	<script>
		var aInp=document.getElementsByTagName('input');
		var oP=document.getElementsByTagName('p')[0];
		aInp[1].onclick=function(){
			var str=aInp[0].value;
			if(!str)return;
			var aSch=oP.innerHTML.split(str);
			if (aSch.length>1){
				oP.innerHTML=aSch.join('<span1>'+str+'</span1>');
			}else{
				alert("没有你要查找的内容");
			}
		};
		aInp[3].onclick=function(){
			var str=aInp[0].value;
			var newstr=aInp[2].value;
			if(!str)return;
			var aSch=oP.innerHTML.split(str);
			if(aSch.length>1){
				oP.innerHTML=aSch.join('<span>'+newstr+'</span>')
			}else{
				alert("没有你要替换的内容");
				
			}
		}
		</script>
</html>

效果图

原文

查找

 

替换

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值