学习Java的日子 Day49 函数,DOM

news2024/9/24 13:22:26

Day48

1.流程控制语句

if else

for

for-in(遍历数组时,跟Java是否一样)

While

do while

break 语句用于跳出循环

continue 用于跳过循环中的一个迭代

2.函数

2.1 JavaScript 函数语法

函数就是包裹在花括号中的代码块,前面使用了关键词 function

function 函数名(参数列表){
…代码块…
}

分类:

无参无返回值的函数

带参数的函数

带返回值的方法

注意:函数就是方法

<body>
<script type="text/javascript">
   		
   //无参无返回值的函数
   function fun01(){
   	console.log("用良心做教育1");
   }
   fun01();
   		
   //带参数的函数
   //注意:形参不需要加类型,调用方法时可以传参也可以不传参
   function fun02(a,b){
   	console.log("用良心做教育2:" + a + " -- " + b);
   }
   fun02();
   fun02(10,20);
   fun02("xxx","yyy");
   fun02("abc",12345);
   		
   //带返回值的方法
   //注意:JS函数里的返回值不用像Java方法里必须指定返回值类型
   function fun03(){
   	return "用良心做教育3";
   }
   var v = fun03();
   console.log(v);
</script>
</body>
2.1.1 函数也是数据

函数也是一种数据,我们可以把函数赋值给一个变量

var add = function(a,b,c){

	return a+b+c;

}	
2.1.2 函数的重载

注意:JS的函数里没有重载的概念

<body>
<script type="text/javascript">
			
	function fun(a,b){
		alert(a+b);
	}
			
	function fun(a,b,c){
		alert(a+b+c);
	}
			
	//a - 10
	//b - 20
	//c - undefind
	fun(10,20);
</script>
</body>
2.2.3 函数的递归

注意:递归是一种思想,只要是面向对象的语言都有这个思想

需求:设计一个函数,传入n,求n的阶乘

<body>
<script type="text/javascript">
			
	function fun(n){
		if(n != 1){
			return fun(n-1)*n;
		}else{
			return 1;
			}
		}
			
	var num = fun(5);
	alert(num);
</script>
</body>

2.2 系统提供的预定义函数

parseInt():试图将其收到的任何输入值转换成整数类型,转换失败则返回NaN

parseFloat():同上类似

isNaN(xxx):判断是否为非数字

isFinite(xxxx):判断输入的是否是一个既非Infinity也非NaN的数字

eval():会将其输入的字符串当作javascript代码来执行 (重要!!!!)

<body>
<script type="text/javascript">
	
	console.log("判断参数是否是数字:" + isFinite("abc"));//false
	console.log("判断参数是否不是数字:" + isNaN("abc"));//true
	console.log("将字符串转换为整数:" + parseInt("100.123"));//100
	console.log("将字符串转换为小数:" + parseFloat("100.123"));//100.123
		
	var str = "alert('用良心做教育');";
	eval(str);//认为字符串为js代码去执行
			
</script>
</body>

3.DOM

采用DOM的方式来操作网页的元素

通过 HTML DOM,可访问 JavaScript HTML 文档的所有元素。

3.1 HTML DOM (文档对象模型)

当网页被加载时,浏览器会创建页面的文档对象模型

HTML DOM 模型被构造为对象的树。

3.2 HTML DOM 树

在这里插入图片描述

通过可编程的对象模型,JavaScript 获得了足够的能力来创建动态的 HTML

JavaScript 能够改变页面中的所有 HTML 元素

JavaScript 能够改变页面中的所有 HTML 属性

JavaScript 能够改变页面中的所有 CSS 样式

JavaScript 能够对页面中的所有事件做出反应

3.3 查找元素

通常,通过 JavaScript,您需要操作 HTML 元素

为了做到这件事情,您必须首先找到该元素,有三种方法来做这件事:

通过 id 找到 HTML 元素

通过标签名找到 HTML 元素

通过类名找到 HTML 元素

注意:document表示该文档,就是dom树

3.3.1 通过id查找 getElementById

在 DOM 中查找 HTML 元素的最简单的方法,是通过使用元素的 id

注意:getElementById获取到的是单个对象

<body>
		
<span id="span01">用良心做教育</span>
<br />
<span>做真实的自己</span>
		
<script type="text/javascript">
			
	//通过id获取元素
	var span01 = document.getElementById("span01");
			
	//绑定单击事件
	span01.onclick = function(){
		//设置内容
		span01.innerHTML = "做真实的自己";
	}
			
</script>
</body>
3.3.2 通过标签名查找 getElementsByTagName

通过标签名查找 HTML 元素

注意:getElementsByTagName获取到的是数组,要用[0],[1]去选择

<body>
		
<span>用良心做教育</span>
<br />
<span>做真实的自己</span>
		
<script type="text/javascript">
			
	//通过标签获取元素数组
	var span01 = document.getElementsByTagName("span")[0];
			
	//绑定单击事件
	span01.onclick = function(){
		//设置内容
		span01.innerHTML = "xxxx";
	}
			
</script>
</body>
3.3.3 通过class查找 getElementsByClassName

通过class查找 HTML 元素

注意:getElementsByClassName获取到的是数组,要用[0],[1]去选择

<body>
		
<span class="myclass">用良心做教育</span>
<br />
<span class="myclass">做真实的自己</span>
		
<script type="text/javascript">
			
	//通过class属性获取元素数组
	var span01 = document.getElementsByClassName("myclass")[0];
			
	//绑定单击事件
	span01.onclick = function(){
       	//设置内容
	    span01.innerHTML = "xxxx";
	}
			
</script>
</body>
3.3.4 通过name查找 getElementsByName

注意:getElementsByName获取到的是数组,要用[0],[1]去选择

<body>
		
<img name="xxx" src="../../img/小米.jpg" />
<img name="xxx" src="../../img/小米.jpg" />
		
<script type="text/javascript">

    //通过name属性获取元素数组
	var img = document.getElementsByName("xxx")[0];
			
	//绑定单击事件
	img.onclick = function(){
		//设置属性
		img.src = "../../img/华为.jpg";
	}
			
</script>
</body>

3.4 DOM_HTML 操作元素

3.4.1 操作内容

修改 HTML 内容的最简单的方法时使用 innerHTML 属性

如需改变 HTML 元素的内容,请使用这个语法:

document.getElementById(id).innerHTML=new HTML

<body>
    
<button onclick="fun01()">获取内容 - innerText</button>
<button onclick="fun02()">设置内容 - innerText</button>
<br />
<span>用良心做教育</span>
<br />
		
<button onclick="fun03()">获取内容 - innerHTML</button>
<button onclick="fun04()">设置内容 - innerHTML</button>
<br />
<span>用良心做教育</span>
		
<script type="text/javascript">
    
	var span01 = document.getElementsByTagName("span")[0];
	var span02 = document.getElementsByTagName("span")[1];
			
	function fun01(){
		console.log(span01.innerText);
	}
		
	function fun02(){
		span01.innerText = "<h1>做真实的自己</h1>";
	}
			
	function fun03(){
		console.log(span02.innerHTML);
	}
			
	function fun04(){
		//把文本当做html标签设置
		span02.innerHTML = "<h1>做真实的自己</h1>";
	}
			
</script>
</body>

innerHTML,innerText的区别:

innerHTML:把文本当做html标签设置

innerText:文本就是文本

3.4.2 操作属性

如需改变 HTML 元素的属性,请使用这个语法:

document.getElementById(id).attribute=new value

获取属性值:getAttribute

修改属性值:setAttribute

<body>
		
<button onclick="fun01()">获取属性</button>
<button onclick="fun02()">设置属性</button>
<br />
<img src="../../img/小米.jpg" width="100px" height="100px" />
<br />
		
<script type="text/javascript">
		
	var img1 = document.getElementsByTagName("img")[0];
	var img2 = document.getElementsByTagName("img")[1];
			
			
	function fun01(){
		console.log(img2.getAttribute("src"));
		console.log(img2.getAttribute("width"));
		console.log(img2.getAttribute("height"));
	}
			
	function fun02(){
		img2.setAttribute("src","../../img/华为.jpg");
		img2.setAttribute("width","100%");
		img2.setAttribute("height","100%");
	}
			
</script>
</body>

3.4.3 操作css样式

如需改变 HTML 元素的css样式,请使用这个语法:

document.getElementById(id).style.property=new style

<body>
		
<button onclick="fun01()">获取样式</button>
<button onclick="fun02()">设置样式</button>
<br />
<span>用良心做教育</span>
		
<script type="text/javascript">
			
	var span = document.getElementsByTagName("span")[0]
		
	function fun01(){
		console.log(span.style.color);
		console.log(span.style.fontSize);
	}
			
	function fun02(){
		span.style.color = "red";
		span.style.fontSize = "50px";
	}
    
</script>
</body>

3.5 事件

对事件做出反应

我们可以在事件发生时执行 JavaScript,比如当用户在 HTML 元素上点击时。

如需在用户点击某个元素时执行代码,请向一个 HTML 事件属性添加 JavaScript 代码:

οnclick=JavaScript

HTML 事件的例子:

l 当用户点击鼠标时

l 当网页已加载时

l 当鼠标移动到元素上时

l 当输入字段被改变时

l 当提交 HTML 表单时

3.5.1 onclick 单击事件

点击之后,更改标题内容

this代表当前被点击的对象

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		
		<h1 onclick="fun01()">用良心做教育</h1>
		
		<script type="text/javascript">
			var h1 = document.getElementsByTagName("h1")[0];
			function fun01(){
				h1.innerText = "做真实的自己";
			}
		</script>
	</body>
</html>

换一种写法:

this代表当前被点击的对象

obj是随便写的一个对象

<body>
		
<h1 onclick="fun01(this)">用良心做教育</h1>
		
<script type="text/javascript">
			
	function fun01(obj){
		obj.innerText = "做真实的自己";
	}
    
</script>
</body>

换一种写法:

<body>
		
<h1>用良心做教育</h1>
		
<script type="text/javascript">
			
	var h1 = document.getElementsByTagName("h1")[0];
		
	//绑定单击事件
	h1.onclick = function(){
		this.innerText = "做真实的自己";
	}
    
</script>
</body>

3.5.2 onload 页面加载事件

onload 一般可以来做一些网页的环境准备工作

页面加载事件:事件会在页面元素和图像加载完成后立即发生

注意:js是一行一行去执行的

<title></title>
		
<script type="text/javascript">
			
    //页面加载事件:事件会在页面元素和图像加载完成后立即发生
	window.onload = function(){
	var h1 = document.getElementsByTagName("h1")[0];
		h1.onclick = function(){
		this.innerText = "做真实的自己";
		}
	}
			
</script>
		
</head>
<body>
    
    <h1>用良心做教育</h1>		
		
</body>

3.5.3 键盘事件

监听器:

onkeydown:键盘按下事件

onkeypress:键盘按下事件 - 功能键(上下左右、删除键…)是不会被触发的

onkeyup:键盘松开事件

<body>
		
<input type="text" 
	onkeydown="myDown()"
	onkeypress="myPress()"
	onkeyup="myUp()"
/>
		
<script type="text/javascript">
			
	function myDown(){//键盘按下事件
		console.log("down");
	}
			
	function myPress(){//键盘按下事件 - 功能键(上下左右、删除键...)是不会被触发的
		console.log("press");
	}
    
	function myUp(){//键盘松开事件
		console.log("up");
	}
    
</script>
</body>

案例,设置一个文本框,每敲一个字母,会触发将输入文本转换为大写的函数

<body>
		
<input type="text" 
	onkeyup="myUp(this)"
/>
		
<script type="text/javascript">

	function myUp(obj){
		//获取value属性
		var v = obj.value;
		//转大写
		v = v.toUpperCase();
		//设置value属性
		obj.value = v;
	}			
		
</script>
</body>

3.5.4 鼠标移动事件

onMouseDown 按下鼠标时触发
onMouseOver 鼠标经过时触发
onMouseUp 按下鼠标松开鼠标时触发
onMouseOut 鼠标移出时触发
onMouseMove 鼠标移动时触

<body>
		
<img src="../../img/小米.jpg" width="100px" height="100px"
	onmousedown="myDown()"
	onmouseup="myUp()"
	onmousemove="myMove()"
	onmouseover="myOver()"
	onmouseout="myOut()"
/>
		
<script type="text/javascript">
			
	function myDown(){//鼠标按下事件
		console.log("down");
	}
			
	function myUp(){//鼠标松开事件
		console.log("up");
	}
		
	function myMove(){//鼠标移动事件
		console.log("move");
	}
			
	function myOver(){//鼠标移入事件
		console.log("over");
	}
		
	function myOut(){//鼠标移出事件
		console.log("out");
	}
					
</script>
</body>

案例:图片,移入图片中就设置高亮,移出就暗沉

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			img{
				width: 100px;
				height: 100px;
				opacity: 0.3;/*设置透明度*/
			}
		</style>
	</head>
	<body>
		
		<img src="../../img/touxiang01.jpg" />
		<img src="../../img/touxiang02.jpg" />
		<img src="../../img/touxiang03.jpg" />
		<img src="../../img/tx1.jpg" />
		<img src="../../img/tx2.jpg" />
		<img src="../../img/tx3.jpg" />
		<img src="../../img/波多野结衣.jpg" />
		
		<script type="text/javascript">
			
			//动态绑定事件
			var imgArr = document.getElementsByTagName("img");
			for(var i = 0;i<imgArr.length;i++){
				
				var img = imgArr[i];
				img.onmouseover = function(){
					this.style.opacity = 1;
				}
				img.onmouseout = function(){
					this.style.opacity = 0.3;
				}
			}
			
		</script>
	</body>
</html>

运行结果:

在这里插入图片描述

3.5.5 焦点事件 onfocus/onblur

onfocus:获取焦点事件

onblur:失去焦点事件

<body>
		
<input type="text"
	onfocus="myFocus()"
	onblur="myBlur()"	
/>
		
<script type="text/javascript">
			
	function myFocus(){//获取焦点事件
		console.log("focus");
	}
			
	function myBlur(){//失去焦点事件
		console.log("blur");
	}			
			
</script>	
</body>

案例:写一个注册的文本框,默认显示“请输入账号…”,光标定位到之后,自动将里面的信息清除掉

<body>
		
<input type="text"
	value="请输入账号..."//value的内容可以直接显示在文本框里面
	οnfοcus="myFocus(this)"
	οnblur="myBlur(this)"	
/>
		
<script type="text/javascript">
			
	function myFocus(obj){//获取焦点事件
		if(obj.value == "请输入账号..."){
			obj.value = "";
		}
	}
			
	function myBlur(obj){//失去焦点事件
				
	//获取该函数里的代码,如果当前浏览器支持该函数,就返回函数里的代码(字符串),如果不支持就返回undefined
	//alert(obj.value.trim);
				
	//判断浏览器是否兼容次方法
	if(obj.value.trim){
		if(obj.value.trim() == ""){
				obj.value = "请输入账号...";
			}
	}else{
		//注意:IE老版本是不支持trim()
		//将字符串的首尾空格的字符替换成空字符串,以达到去空格的目的
		if(obj.value.replace(/(^\s+)|(\s+$)/g,"") == ""){
				obj.value = "请输入账号...";
			}
		}
								
}
			
</script>
</body>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1701455.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【NumPy】关于numpy.subtract()函数,看这一篇文章就够了

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…

观原力谱能超导实验室原创科普舞台剧能源小队的奇幻旅程第一次对外公演记

昨天发出后&#xff0c;总感觉很多违和之处&#xff0c;斟酌之后略改&#xff1a; 观原力谱能超导实验室原创科普舞台剧 能源小队的奇幻旅程第一次对外公演记 卡西莫多 科学奥妙多奇观 深邃微界有沃原 亿万齐聚窸微力 原子宏观现光谱 物质都有静态能 聚变核能威猛超 国…

29.哀家要长脑子了!

1.224. 基本计算器 - 力扣&#xff08;LeetCode&#xff09; 这道题的特点就是它的运算符只有加和减 那么就可以通过改变数字的正负符号来代表操作加减 因为减去一个数&#xff0c;就是加上这个数的相反数 这个栈不是用来存放数的&#xff0c;而是用来存放操作符号的。代表是…

教育大模型的发展现状、创新架构及应用展望

引言 从通用大模型到教育领域的专用大模型&#xff0c;是人工智能大模型技术深化发展的必然趋势。教育大模型不是在通用大模型基础上的微调和优化&#xff0c;而是以重构未来教育图景为目标、以开放算法模型架构为基础、以创新教育应用场景为核心的系统性变革。如何厘清教育大…

数据丢失不用愁,3个手机数据恢复大师来解忧!

这个信息技术高速发展的时代&#xff0c;手机成为了生活中不可或缺的一部分。无论是重要的工作文件、珍贵的家庭照片&#xff0c;还是那些无法替代的个人记忆&#xff0c;都存储在我们的手机中。然而&#xff0c;生活中总有一些意想不到的情况&#xff0c;比如误删文件、手机丢…

外贸电商数据分析实战指南

亮数据浏览器https://www.bright.cn/proxy-types/?utm_sourcebrand&utm_campaignbrnd-mkt_cn_csdn_yingjie 引言 在行业竞争激烈、市场变化快速的跨境电商领域&#xff0c;数据采集可以帮助企业深入了解客户需求和行为&#xff0c;分析市场趋势和竞争情况&#xff0c;从而…

目标检测——无人机图像数据集

引言 亲爱的读者们&#xff0c;您是否在寻找某个特定的数据集&#xff0c;用于研究或项目实践&#xff1f;欢迎您在评论区留言&#xff0c;或者通过公众号私信告诉我&#xff0c;您想要的数据集的类型主题。小编会竭尽全力为您寻找&#xff0c;并在找到后第一时间与您分享。 …

即刻起飞——基于Amazon Bedrock快速构建生成式AI应用

即刻起飞 —— 基于 Amazon Bedrock 快速构建生成式 AI 应用 1. 前言 在百模大战中&#xff0c;AI行业的发展正在经历前所未有的变革。这场竞争不仅推动了AI技术的快速发展&#xff0c;也揭示了AI行业的新趋势。这些趋势不仅影响着我们如何看待和使用AI&#xff0c;也预示着AI…

矩阵区域和 ---- 二维前缀和

题目链接 题目: 分析: 题目的题意是:矩阵和的问题, 应该使用二维前缀和来解决 先预处理一个前缀和, 但是题目中下标是从0开始的, 为了不处理边界情况, 我么预处理出来的矩阵, 要从下标为1的位置开始, 所以前缀和矩阵的大小为m1 * n1预处理前缀和:dp[i][j] 表示: 从[1,1] 位置…

音视频开发7 音视频转换格式流程

先看条转换视频文件的命令 我们的目的是将 源文件 source_1920x1080.mp4 转换成 目标文件 dest_1280x720.flv ffmpeg -i source_1920x1080.mp4 -acodec copy -vcodec libx264 -s 1280x720 dest_1280x720.flv -acodec copy 的意思是&#xff0c;目标的 音频格式 使用和 源文…

【C++初阶】auto关键字

目录 1.auto简介 2.auto的使用 1.auto简介 在早期C/C中auto的含义是&#xff1a;使用auto修饰的变量&#xff0c;是具有自动存储器的局部变量&#xff0c;但遗憾的 是一直没有人去使用它&#xff0c;大家可思考下为什么&#xff1f; C11中&#xff0c;标准委员会赋予了auto全…

深入理解布瑞克(break)逻辑与嵌套循环的奥秘

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、引言&#xff1a;布瑞克逻辑是什么&#xff1f; 二、布瑞克逻辑在嵌套循环中的应用 1.…

高奇琦:从大国协调到全球性机制:人工智能大模型全球治理路径探析

内容提要 人工智能大模型全球治理的关键是对大模型进行科学分类。大模型可以分为超大模型和一般模型。对于超大模型的治理&#xff0c;可以参考核武器治理的思路&#xff0c;重点是实现超大模型的有限发展和不扩散。对于一般模型而言&#xff0c;要在安全可控的基础上发挥其对…

【算法】排序——加更

补充1个排序&#xff1a;希尔排序 思路&#xff1a;首先定义一个gap,从第0个数开始&#xff0c;每隔一个gap取出一个数&#xff0c;将取出来的数进行比较&#xff0c;方法类似插入排序。第二轮从第二个数开始&#xff0c;每隔一个gap取出一个数再进行插入排序。四轮就可以取完…

项目启动 | 晟泰克再度牵手盘古信息,引入IMS V6系统实现数字化深度推进

当前&#xff0c;中国汽车零部件行业的数字化转型正在快速推进&#xff0c;数字化工业软件已经广泛应用于汽车零部件的研发、生产和服务等各个环节&#xff0c;赋能行业实现降本减存&#xff0c;提质增效&#xff0c;有力推动了行业高质量发展。 成立于2003年的合肥晟泰克汽车…

【加密与解密(第四版)】第十八章笔记

第十八章 反跟踪技术 18.1 由BeginDebugged引发的蝴蝶效应 IsDebuggerPresent()函数读取当前进程PEB中的BeginDebugged标志 CheckRemoteDebuggerPresent() 反调试总结&#xff1a;https://bbs.kanxue.com/thread-225740.htm https://www.freebuf.com/articles/others-articl…

【数据结构】红黑树——领略天才的想法

个人主页&#xff1a;东洛的克莱斯韦克-CSDN博客 祝福语&#xff1a;愿你拥抱自由的风 目录 二叉搜索树 AVL树 红黑树概述 性质详解 效率对比 旋转操作 元素操作 代码实现 二叉搜索树 【数据结构】二叉搜索树-CSDN博客 AVL树 【数据结构】AVL树——平衡二叉搜索…

GitHub打不开的解决方案

1、打开https://sites.ipaddress.com/github.com/找到DNS Resource Records&#xff0c;复制github的ip地址&#xff0c;先保存起来&#xff1a; 140.82.112.32、打开https://sites.ipaddress.com/fastly.net/找到DNS Resource Records&#xff0c;复制其中一个ip地址&#xf…

ComfyUI 高级实战:极速稳定视频风格转绘

大家好&#xff0c;我是每天分享AI应用的萤火君&#xff01; 重绘视频一直是短视频平台上的热点内容&#xff0c;流量不错。重绘视频一般是将真实视频重绘为动漫风格&#xff0c;或者是使用新的人物形象重放视频中的人物动作&#xff0c;再或者只是重绘视频中的部分内容&#…

Android 音视频从入门到提高 -- 任务列表——task1

1.在 Android 平台绘制一张图片&#xff0c;使用至少3种不同的 APl&#xff0c;lmageView&#xff0c;SurfaceView&#xff0c;自定义 Vew 布局xml <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.a…