web前端——javaScript

目录

一、javaScript概述

1.javaScript历史

2.JavaScript与html,css关系

二、基本语法

①放在head中 

②放在 body中  

③写在外部的.js文件中

1.变量

2.数据类型

3.算术运算符 

4.逻辑运算符

5.赋值运算 

6.逻辑运算符 

7.条件运算符

8.控制语句 

三、函数

1.函数定义的基本语法

2.函数调用

3.全局函数

四、内置对象

1.String字符串

2.Array数组

3.Date

4.Math 

五、事件

六、Html DOM对象

1.Html DOM概述

 2.查找元素

 3.改变HTML

 4.改变CSS

七、计时


一、javaScript概述

1.javaScript历史

● JavaScript是由Netscape公司(美国网景公司)开发的一种脚本语言。

● Netscape公司将这种脚本语言命名为LiveScript,与java一样,也是面向对象的语言,而且无需编译,可由浏览器直接解释运行。

● Netscape公司见LiveScript大有发展前途,而SUN公司( java)也觉得可以利用Livescript为Java的普及做铺垫,于是两家签订协议将LiveScript改为JavaScript

● JavaScript一种直译式脚本语言,用来为网页添加各式各样的动态功能 (javaScript可以操作网页内容),不需要编译可直接通过浏览器解释运行,通常JavaScript脚本是通过嵌入在HTML中来实现自身的功能的。

2.JavaScript与html,css关系

JavaScript是一种基于对象和事件驱动并具有安全性的解释性语言,其目的就是增强Web客户交互,弥补了HTML的缺陷

二、基本语法

脚本写在哪里?

javaScript脚本写在一组<script>标签中,此标签可以放在head中或body中,一般习惯放在 head中,还可以将脚本写在外部的.js文件中,在html页面中导入外部的.js文件

第一个JavaScript程序
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<script src="js/index.js"></script>
		<script>
			//调用对话框库函数
			//alert("大家好 我是js!"); 
			alert("hello js!")
		</script>
	</head>
	<body>
	</body>
</html>
对话框
alert(‘welcome!’); 提示对话框

 ①放在head中 

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<script>
			alert("hello js!")
		</script>
	</head>
	<body>
	</body>
</html>

②放在 body中  

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
	</head>
	<body>
        <script src="js/index.js"></script>
	</body>
</html>

③写在外部的.js文件中

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<script src="js/index.js"></script>
	</head>
	<body>
	</body>
</html>

1.变量

● 声明变量用var关键字  例如 var name;

● 声明变量的同时对其赋值   var test=“THIS IS A BOOK”

2.数据类型

javaScript支持的数据类型

● ①数值型(number): 其中包括整型数和浮点型数。

● ②布尔型(boolean): 即逻辑值,true或flase。

● ③字符串型: 由单个或多个文本字符组成。字符串是用单引号或双引号来说明的。(使用单引号来输入包含引号的字符串)

● ④undefined类型

● ⑤Object类型

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script>
			/* 数据类型 */
			
			//1.数值类型(包含整数和浮点数)
			var a = 10;
			var b = 10.5; 
			/* alert(typeof(b));number  typeof(b)返回变量的数据类型 */
			
			//2.布尔类型
			var c = true;
			var d = false;
			/* alert(a==b); */
			
			//3.字符串,单引号和双引号都表示字符串
			var e = "abcd";
			var f = 'abcd';
			/* alert(typeof(e));
			alert(typeof(f)); */
			
			//4.undefined 声明了变量,却没有
			var g;
			alert(g==undefined);
			
			//对象类型
			var date = new Date();
			/* alert(date.getFullYear());
			alert(date.getMonth()+1);
			date.getDate(); */
	
		</script>
	</head>
	<body>
	</body>
</html>

3.算术运算符 

+:可以进行“加法”与“连接”运算,如果2个运算符中的一个是字符串,javascript就将另一个转换成字符串,然后将2个运算数连接起来

-:"字符串"-数值=数值,如果2个运算符中的一个是字符串,会把表达式中的数字字符串尝试类型转换,如果字符串不能转换为数值 ,返回NaN

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script>
			/* 
			 算术运算符 + - * / % ++ --
			 + 加法运算 字符串运算
			 */
			 var a = "10";
			 var b = 5;
			 var c = 10;
			 var d = "a";
			 //alert(a+b);//字符串连接 105
             //alert(b+c);//加法 15
			 
			 /* alert(c-b);//5 减法
			 alert(a-b);//5 "字符串"-数值=数值  会把表达式中的数字字符串尝试类型转换
			 alert(c-d);//NaN not a number 如果字符串不能转换为数值 返回NaN */
			 
			// alert(a*b);//50
			// alert(a*d);//NaN
		</script>
	</head>
	<body>
	</body>
</html>

4.逻辑运算符

逻辑运算符用于测定变量或值之间的逻辑,给定 x=6 以及 y=3 ,下表解释了逻辑运算符:
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script>
			 var a = "10";
			 var b = 5;
			 var c = 10;
			 var d = "a";
			// alert(a==c);//只比较值是否相等
			// alert(a===c);//全等(值和类型)
		</script>
	</head>
	<body>
	</body>
</html>

5.赋值运算 

6.逻辑运算符 

逻辑运算符用于测定变量或值之间的逻辑,给定 x=6 以及 y=3 ,下表解释了逻辑运算符:

7.条件运算符

JavaScript 还包含了基于某些条件对变量进行赋值的条件运算符
语法:
var result = (条件表达式)?结果1:结果2
当条件成立返回?后的内容,否则返回:后的内容

8.控制语句 

第一种是选择结构
单一选择结构(if)
二路选择结构(if/else)
多路选择结构(switch)
第二种类型的程序控制结构是循环结构
由计数器控制的循环(for)
在循环的开头测试表达式(while)
在循环的末尾测试表达式(do/while)
break continue
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script>
			 var a = "10";
			 var b = 5;
			 var c = 10;
			 var d = "a";
			if(c>b){
				alert(c);
			} 
			 
			for (var i = 0;i < 5;i++){
				alert(i);
			}
		</script>
	</head>
	<body>
	</body>
</html>

三、函数

1.函数定义的基本语法

function functionName([arguments]){
    javascript statements
    [return expression]
}
function: 表示函数定义的关键字
functionName:表示函数名
arguments:表示传递给函数的参数列表,各个参数之间用逗号隔开,可以为空
statements: 表示实现函数功能的函数体
return expression:表示函数将返回expression的值,同样是可选的的语句

2.函数调用

由函数来调用
<script type= "text/javascript">
function fun(){
  alert(“test”);
}
fun();//函数名调用
function fun2(){
fun();//在其他函数中调用
}
</script>

3.全局函数

parseInt(arg) 把括号内的内容转换成整数之后的值。如果括号内是字符串, 则字符串开头的数字部分被转换成整数,如果以字母开头,则返回 “NaN” 
parseFloat(arg) 把括号内的字符串转换成浮点数之后的值,字符串开头的数字部分被转换成浮点数,如果以字母开头,则返回“NaN” 
typeof (arg)返回arg值的数据类型
eval(arg) 可运算某个字符串
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script>
		//①无参构造方法
	    /*
        function test(){
			alert("你好");
		} */
		//②有参构造方法
		/* 
		function test(a,b,c){
			alert(a+":"+b+":"+"c");
		}
		*/
		//有返回值
		/* 
		 function test(a,b){
			 return a+b;
		 }
		 */
	   //函数调用
	 /*  test(); 
	   
	   test(true,"abc",new Date()); 
	   
	   var c = test(10,23);
	   alert(c); */
	   
	   //系统中的全局函数 在系统已经定义好了,直接调用的函数
	   //alert(输出内容); 弹窗显示
	   
	    var a = 10.5;
		var b = "10.5";
		var c = 5;
		alert(parseInt(a));//把浮点数转为整数
		alert(parseInt(b)+c);//把字符串更换转换成整数, 如果转换的内容是字符串,字母不能开头, 只将开头的数字部分转换
		alert(parseFloat(c));
		alert(parseFloat(b));	
		alert(typeof(a));
		alert(typeof(b)); //typeof(变量)  获取变量的数据类型
		var s = "2+3*2"; var s = 2+3*2;
		var s = "alert(a)";
		eval(s);//把传入进来的字符串可以当做js脚本执行		
		</script>
	</head>
	<body>
	</body>
</html>

四、内置对象

1.String字符串

●属性
length 用法:返回该字符串的长度
●方法
charAt(n) :返回该字符串位于第 n 位的单个字符
indexOf(char) :返回指定 char 首次出现的位置
lastIndexOf(char) :跟 indexOf() 相似,不过是从后边开始找
substring(start,end) :返回原字符串的子字符串,该字符串是原字符串从 start 位置到end 位置的前一位置的一段 .
substr(start,length) :返回原字符串的子字符串,该字符串是原字符串从 start 位置开始,长度为length 的一段
split( 分隔符字符 ) :返回一个数组,该数组是从字符串对象中分离开来的, < 分隔符字符> 决定了分离的地方,它本身不会包含在所返回的数组中
例如:'1&2&345&678'.split('&')返回数组:1,2,345,678

2.Array数组

数组的定义方法:
  var <数组名> = new Array();
这样就定义了一个空数组,以后要添加数组元素,就用:
  <数组名>[下标] = 值;
如果想在定义数组的时候直接初始化数据,请用:
  var <数组名> = new Array(<元素1>, <元素2>, <元素3>...);
还可以
  var <数组名> = [<元素1>, <元素2>, <元素3>...];
●属性
length :数组的长度,即数组里有多少个元素
●方法
join(<分隔符>) : 返回一个字符串,该字符串把数组中的各个元素串起来,用 < 分隔符> 置于元素与元素之间
reverse(): 使数组中的元素顺序反过来。如果对数组 [1, 2, 3] 使用这个方法,它将使数组变成:[3, 2, 1]
sort() : 使数组中的元素按照一定的顺序排列。如果不指定 < 方法函数 > ,则按字母顺序排列
对数字排序需要调用排序函数
function sortNumber(a,b){
  return a - b;
}

 3.Date

● 获取日期

new Date() 返回当日的日期和时间
getFullYear() 返回四位数字年份
getDate() 返回一个月中的某一天 (1 ~ 31)
getMonth() 返回月份 (0 ~ 11)
getDay() 返回一周中的某一天 (0 ~ 6)
getHours() 返回 Date 对象的小时 (0 ~ 23)
getMinutes() 返回 Date 对象的分钟 (0 ~ 59)
getSeconds() 返回 Date 对象的秒数 (0 ~ 59))

4.Math 

● Math 对象,提供对数据的数学计算

● 属性

PI 返回π(3.1415926535...)

● 方法 

Math.abs(x) 绝对值计算;
Math.pow(x,y) 数的幂;x的y次幂
Math.sqrt(x) 计算平方根;
Math.ceil(x) 对一个数进行上舍入
Math.floor(x) 对一个数进行下舍入。
Math.round(x) 把一个数四舍五入为最接近的整数
Math.random() 返回 0 ~ 1 之间的随机数
Math.max(x,y) 返回 x 和 y 中的最大值
Math.min(x,y) 返回 x 和 y 中的最小值 

五、事件

● 一些常用的事件

onclick()鼠标点击时;
onblur()标签失去焦点;
onfocus()标签获得焦点;
onmouseover()鼠标被移到某标签之上;
onmouseout鼠标从某标签移开;
onload()是在网页加载完毕后触发相应的的事件处理程序;
onchange()是指当前标签失去焦点并且标签的内容发生改变时触发事件处理程序。

六、Html DOM对象

1.Html DOM概述

● DOM是Document Object Model文档对象(网页中的标签)模型的缩写
● 通过html dom,可用javaScript操作html文档的所有标签

 2.查找元素

● 通常,通过 JavaScript,您需要操作 HTML 标签
● 为了做到这件事情,您必须首先找到该标签
● 要操作,先得到
● 有四种方法来做这件事:
①通过 id 找到 HTML 标签
document.getElementById(“id");
②通过标签名找到 HTML 标签
document.getElementsByTagName("p");
③通过类名找到 HTML 标签
document.getElementsByClassName("p");
④通过name找到 HTML 标签
document.getElementsByName(“name");

 3.改变HTML

● Html dom允许javaScript 改变html标签的内容

  • 改变 HTML 标签的属性
  document.getElementById(“username").value=“new value";
  document.getElementById("image").src=“new.jpg";
  • 修改 HTML 内容的最简单的方法时使用 innerHTML 属性
  document.getElementById( “div”).innerHTML= new HTML  

 4.改变CSS

● html dom允许 javaScript改变html标签的样式
语法:
document.getElementById("id").style.property=new style;
例:
document.getElementById("p2").style.backgroundImage="url(bg.jpg)";

七、计时

● 通过使用 JavaScript,我们有能力做到在一个设定的时间间隔之后来执行代码,而不是在函数被调用后立即执行,我们称之为计时事件
●  方法
  setTimeout(“函数”,”时间”)未来的某时执行代码
  clearTimeout()取消setTimeout()
  setInterval(“函数”,”时间”)每隔指定时间重复调用
  clearInterval()取消setInterval()
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script>
			function hello(){
				console.log("下午好");
			}
			/* var t = setTimeout("hello()",5000);//设定指定时间后调用指定的函数,只调用一次 */
			var t;
			function startTime(){
				t = setInterval("hello()",1000);
			}
			function stopTime(){
				/* clearTimeout(t);//取消定时器 */
				clearInterval(t);
			}
		</script>
	</head>
	<body>
		<input type="button" value="开始" onclick="startTime()"/>
		<input type="button" value="停止" onclick="stopTime()"/>
	</body>
</html>

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

《数字图像处理》实验报告六

一、实验任务与要求 比较采用不同的色彩空间对彩色图像处理的效果&#xff0c;处理包括&#xff1a; a&#xff09;直方图均衡化 b&#xff09;图像增强 二、实验报告 &#xff08;一&#xff09;RGB色彩空间的直方图均衡化 / 锐化处理 1、matlab 实现代码&#xff1a; %…

Vue中数组的【响应式】操作

在 Vue.js 中&#xff0c;当你修改数组时&#xff0c;Vue 不能检测到以下变动的数组&#xff1a; 当你利用索引直接设置一个项时&#xff0c;例如&#xff1a;vm.items[indexOfItem] newValue当你修改数组的长度时&#xff0c;例如&#xff1a;vm.items.length newLength 为…

谷歌上搞下来的,无需付费,可以收藏!

在数字化时代&#xff0c;我们越来越依赖于智能设备来获取信息和知识。中国智谋App正是这样一款应用&#xff0c;它将中国古代的智慧与谋略书籍带入了我们的移动设备&#xff0c;让我们能够随时随地学习和领悟。而且提供文言文的原文和译文。 软件下载方式&#xff1a;谷歌上搞…

39.右键弹出菜单管理游戏列表

上一个内容&#xff1a;38.控制功能实现 以 ​​​​​​​ 38.控制功能实现 它的代码为基础进行修改 效果图&#xff1a; 点击设置之后的样子 点击删除 点击删除之后的样子 实现步骤&#xff1a; 首先添加一个菜单资源&#xff0c;右击项目资源选择下图红框 然后选择Menu 然…

Docker(九)-Docker运行redis6.0.8容器实例

1.宿主机新建目录存放redis.conf文件 目的&#xff1a;运行redis容器实例时使用自己的配置文件2.运行redis容器实例 docker run -d -p 6379:6379 --privilegedtrue -v 【宿主机配置文件目录】:/etc/redis/redis.conf -v 【宿主机数据目录】:/data --nameredis6.0.8 redis:6.0…

Keka for Mac:轻量级压缩解压神器

Keka for Mac是一款专为Mac用户打造的轻量级压缩解压软件&#xff0c;凭借其强大的功能和简洁易用的界面&#xff0c;赢得了众多用户的喜爱。无论是日常办公还是学习娱乐&#xff0c;Keka都能为您提供高效、安全的文件压缩和解压体验。 Keka for Mac v1.4.2中文版下载 产品特点…

记录一次CMS的代码审计

本次代码审计使用了白加黑的手法&#xff0c;用黑盒的视角测试功能点&#xff0c;用白盒的方式作为验证。 0x1 XSS guestbook处&#xff0c;可以看到有一个留言板 idea搜索guestbook。发现代码如下&#xff0c;其中的getModel是获取数据的方法。Guestbook.class就是具体要获取…

MySQL索引优化解决方案--索引介绍(1)

什么是索引 MySQL官方对于索引的定义&#xff1a;索引是帮助MySQL高效过去数据的数据结构。 MySQL在存储数据之外&#xff0c;数据库系统中还维护着满足特定查找算法的数据结构&#xff0c;这些数据结构以某种引用&#xff08;指向&#xff09;表中的数据&#xff0c;这样我们…

使用ChatGPT提升编程效率:程序员的最佳实践分享

在这个信息技术飞速发展的时代&#xff0c;编程已经成为了越来越多人的必备技能。无论你是初学者&#xff0c;还是经验丰富的开发者&#xff0c;都可能会遇到编程中的各种问题和挑战。幸运的是&#xff0c;AI 技术的进步让我们有了新的解决工具——ChatGPT。作为一名科技博客博…

51单片机STC89C52RC——9.1 DS1302涓流充电计时芯片

目录 目的/效果 一&#xff0c;STC单片机模块 二&#xff0c;DS1302计时器 2.1 特性/板子位置 2.1.1 特性 2.1.2 板子上的位置 2.2 针脚定义 2.3 数据传输 2.3.1 读数据 2.3.2 写数据 2.4 BCD码 2.5 可编程涓流充电器 2.6 时钟动态设置 三&#xff0c;创建Keil项目…

Leetcode 102.目标和

给定一个正整数数组 nums 和一个整数 target 。 向数组中的每个整数前添加 ‘’ 或 ‘-’ &#xff0c;然后串联起所有整数&#xff0c;可以构造一个 表达式 &#xff1a; 例如&#xff0c;nums [2, 1] &#xff0c;可以在 2 之前添加 ‘’ &#xff0c;在 1 之前添加 ‘-’ &…

2024最新pd激活码 Parallels Desktop 19 激活秘钥分享

Parallels Desktop 19 for Mac 乃是一款适配于 Mac 的虚拟化软件。它能让您在 Mac 计算机上同时运行多个操作系统。您可借此创建虚拟机&#xff0c;并于其中装设不同的操作系统&#xff0c;如 Windows、Linux 或 macOS。使用 Parallels Desktop 19 mac 版时&#xff0c;您可在 …

【UE5.3】笔记2--资源导入

资源导入 方式一&#xff1a;内置资源--初学者内容包 方式二&#xff1a;虚幻商城 搜索免费资源&#xff1a; 添加到工程之后 搜素&#xff1a;虚幻学习工具包&#xff0c;需要注意的是支持的引擎版本 当然商城里包含了大量的免费的资源&#xff0c;初期学习不想投入太多可以…

OpenCL在移动端GPU计算中的应用与实践

一、引言 移动端芯片性能的不断提升为在手机上进行计算密集型任务&#xff0c;如计算机图形学和深度学习模型推理&#xff0c;提供了可能。在Android设备上&#xff0c;GPU&#xff0c;尤其是高通Adreno和华为Mali&#xff0c;因其卓越的浮点运算能力&#xff0c;成为了异构计…

OZON跨境卖家爆款产品有哪些

OZON跨境卖家爆款产品有哪些&#xff1f;国内的Ozon跨境卖家做这几个品&#xff0c;不爆都难&#xff01; Top1 太阳镜 Очки солнцезащитные 商品id&#xff1a;1556874194 月销量&#xff1a;1095 OZON跨境卖家爆款产品工具&#xff1a;D。DDqbt。COm/…

【Docker】Docker简介_运行原理

1、简介 1.1基本概念 容器&#xff1a;容器是Docker的基本部署单元。它是一个轻量级的、独立的运行时环境&#xff0c;包含应用程序及其相关依赖。容器利用Linux内核的命名空间和控制组技术&#xff0c;实现了隔离性和资源管理&#xff0c;使得应用程序在不同的容器中运行不会…

2024 最新运营小工具 API 推荐,助力高效工作

在当今数字化运营的时代&#xff0c;各种高效便捷的 API 服务成为了企业和个人提升运营效率、获取精准数据的得力助手。无论是进行市场调研、拓展业务&#xff0c;还是优化网络资源配置&#xff0c;都离不开这些强大的工具。本文将为您详细介绍一系列实用的运营小工具 API 服务…

使用API有效率地管理Dynadot域名,为文件夹更名

关于Dynadot Dynadot是通过ICANN认证的域名注册商&#xff0c;自2002年成立以来&#xff0c;服务于全球108个国家和地区的客户&#xff0c;为数以万计的客户提供简洁&#xff0c;优惠&#xff0c;安全的域名注册以及管理服务。 Dynadot平台操作教程索引&#xff08;包括域名邮…

【HarmonyOS4学习笔记】《HarmonyOS4+NEXT星河版入门到企业级实战教程》课程学习笔记(十八)

课程地址&#xff1a; 黑马程序员HarmonyOS4NEXT星河版入门到企业级实战教程&#xff0c;一套精通鸿蒙应用开发 &#xff08;本篇笔记对应课程第 28 节&#xff09; P28《27.网络连接-Http请求数据》 案例&#xff1a; 这里不懂后端假设服务器的前端小伙伴就需要课程源码资料了…

华三交换机的软件版本升级操作

升级操作很常见&#xff0c;掌握方法是关键 实验环境&#xff1a;1台华三S6520-EI交换机&#xff0c;版本从2432P03升级成2432P05。 整体思路&#xff1a; 1.先查验软件版本 2.官网下载对于设备型号的软件版本 3.配置交换机地址使得与电脑进行通信&#xff0c;使用TFTP/FTP工…