JavaScript入门

5 篇文章 0 订阅
这篇博客介绍了JavaScript入门的基础知识,包括JavaScript与HTML的结合方式、变量和数据类型、事件处理、DOM模型以及正则表达式。重点讲述了Document对象的方法、事件的静态和动态注册,以及如何通过getElementByName和getElementByTagName方法操作DOM。
摘要由CSDN通过智能技术生成

javaScript入门

JavaScript结合html的两种使用方式

方式一:JavaScript代码直接写在html文件内

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<!-- 使用script标签 -->
		<script type="text/javascript">
			//alert 是javaScript语言提供的一个警告框函数
			//可以接受任意类型的参数,这个参数就是警告框的提示信息
			alert("hello javaScript");//运行JavaScript程序的时候就会弹出警告
		</script>
	</head>
	<body>
	</body>
</html>

方式二:html导入JavaScript文件

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<!-- 现在需要使用script标签引入外部的js文件来执行 
			src 属性专门用来引入js文件路径(可以是相对路径,也可以还是绝对路径)
			
			script标签可以用来定义js代码,也可以用来引入js文件
			但是两个功能二选一使用,不能同时使用。
		-->
		<script type="text/javascript" src="02.js">	</script>
	</head>
	<body>
	</body>
</html>
alert("hello javaScript");

javaScript的变量和数据类型介绍

javaScript 的变量类型:
数值类型:		number
字符串类型:		string
对象类型:		object
布尔类型:		boolean
函数类型:		function

javaScript 里的特殊值:
undefined		未定义,所以js变量未赋予初始值的时候,默认值都是undefined
null			空值
NAN		全称:Not a Number,非数字,非数值。

js中的定义变量格式:
var 变量名;
var 变量名 =;
var i;
alert(i);//undefined

在这里插入图片描述

var i;
// alert(i);//undefined
i=12;
alert(typeof(i));//typeof是JavaScript语言提供的一个函数,它可以取变量的数据类型返回

在这里插入图片描述

var i;
// alert(i);//undefined
i=12;
// alert(typeof(i));//typeof是JavaScript语言提供的一个函数,它可以取变量的数据类型返回
i="abc";
alert(typeof(i));//JavaScript是弱类型语言,此时的i变成了string类型

在这里插入图片描述

var a=12;
var b="abc";
alert(a*b);//a是数值型,b是字符串型

在这里插入图片描述

关系运算

//大于、大于等于、小于、小于等于与java相同
== 等于:简单的做字面值的比较
=== 全等于:除了做字面值的比较外,还会比较数据类型
var a=12;
var b="12";
alert(a==b);\\true
alert(a===b);\\false

逻辑运算

且运算: &&
或运算: ||
取反运算: !

在 JavaScript 语言中,所有的变量,都可以做为一个 boolean 类型的变量去使用。
0nullundefined、””(空串) 都认为是 false&& 且运算。
有两种情况:
	第一种:当表达式全为真的时候。返回最后一个表达式的值。
	第二种:当表达式中,有一个为假的时候。返回第一个为假的表达式的值

|| 或运算
	第一种情况:当表达式全为假时,返回最后一个表达式的值
	第二种情况:只要有一个表达式为真。就会把回第一个为真的表达式的值
	
并且 && 与运算 和 ||或运算 有短路。
短路就是说,当这个&&||运算有结果了之后 。后面的表达式不再执
// 在 JavaScript 语言中,所有的变量,都可以做为一个 boolean 类型的变量去使用。
//0 、null、 undefined、””(空串) 都认为是 false;
			
var a=0;
if(a){
	alert("0为真");
}else{
	alert("0为假");
}
			
var c=null;
if(c){
	alert("null为真");
}else{
	alert("null为假");
}

var c=undefined;
if(c){
	alert("undefind为真");
}else{
	alert("undefind为假");
}
			
var d="";
if(d){
	alert("空串为真");
}else{
	alert("空串为假");
}
/*
&& 且运算。
有两种情况:
	第一种:当表达式全为真的时候。返回最后一个表达式的值。
	第二种:当表达式中,有一个为假的时候。返回第一个为假的表达式的值
*/
var a="abc";
var b=true;
var c=false;
var d=null;
alert(a&&b);//true
alter(b&&a);//true
alert(a&&c);//false
alter(a&&d);//null
alert(a && c && d);//false
/*
|| 或运算
	第一种情况:当表达式全为假时,返回最后一个表达式的值
	第二种情况:只要有一个表达式为真。就会把回第一个为真的表达式的值
*/
var a="abc";
var b=true;
var c=false;
var d=null;
alert(d||d);//null
alert(d||c);//false
alert(a||c);//abc
alert(b||c)//true

数组(*)

js中数组的定义:
	格式:
	var 数组名 = []; //空数组
	var 数组名 = [1,'abc',true];//定义数组同时赋值元素
var arr=[];//空数组
alert(arr.length);//0
			
arr[0]=12;
alert(arr[0]);//12
alert(arr.length);//1
			
arr[2]="abc";
alert(arr[2]);//13
alert(arr.length);//3
//JavaScript语言中的数组,只要我们通过下标赋值,那么最大的下标值就会自动给下标做扩容操作。
alert(arr[1]);//undefined
			
for(var i=0;i<arr.length;i++){
	alert(arr[i])
}

函数(*)

函数两种定义方式:
函数的第一种定义方式:可以使用function关键字来定义函数。

//使用的格式如下:
function 函数名(形参列表){
	函数体;
}

//演示代码:
function fun1(){
	alert("无参函数fun1()被调用");
}
fun1();//函数调用才会执行。
			
function fun2(a,b){//不需要指定类型,只需要告诉函数变量的个数和参数名
	alert("有参函数fun2()被调用 a="+a+",b="+b);
}
fun2("abc",123);

//在JavaScript语言中如何定义带有返回值得函数?
	//只需要在函数体内直接使用return语句返回值即可。
function sum(num1,num2){//定义带有返回值得函数
var result = num1+num2;
	return result;
}
alert(sum(12,56));

函数的第二种定义方式

//函数的第二种定义方式,格式如下:
var 函数名 = function(形参列表){
	函数体
}

//演示代码(与第一种方式没有区别)
var fun1 = function(){
	alert("调用无参函数fun1()")
}
fun1();

var fun2 = function(a,b){
	alert("有参函数:a="+a+",b="+b);
}
fun2(12,"abc");
			
var fun3 = function(num1,num2){
	var result=num1+num2;
	return result;
}
alert(fun3(12,78));

注:在java中函数允许重载,但是在JavaScript当中,重载会直接覆盖上次的定义

function fun(a,b){
	alert("有参函数fun(a,b)");
}
function fun(){
	alert("无参函数fun()");
}
fun(12,"abc");//虽然传递了参数,但是调用的却是无参函数
function fun(){
	alert("无参函数fun()");
}
function fun(a,b){
	alert("有参函数fun(a,b)");
}
fun();//虽然没有传递参数,但是只能调用下面的有参函数

虽然没有传递参数,但是依然不会报异常,以为在JavaScript当中提供了一个功能:
函数的 argument 隐形参数(只有在function函数内)
在function函数中,不需要定义,但却可以直接用来获取所有参数的变量,我们管它叫隐形参数。
隐形参数特别像java当中的可变长参数。

public void fun(Object ...args){
}//可变长参数其实是一个数组

那么JavaScript中的隐形参数也像java当中的可变长参数一样,操作类似的数组。

function fun(){
alert(arguments);//Object argument
alert(arguments.length);//参数个数
for (var i = 0; i < arguments.length; i++) {
	alert(arguments[i]);
}
	alert("无参函数fun()");
}
fun(1,"ab");

//需求:编写一个函数,用于计算所有参数相加的和并返回
function sum(num1,num2){
	var result = 0;
	for(var i=0;i<arguments.length;i++){
		if(typeof(arguments[i])== "number")
		result += arguments[i];
	}
	return result;
}
alert(sum(1,2,3,4,5,6,7,8,9,10));//55
alert(sum(1,2,3,4,5,"abc",7,8,9,10));

JavaScript中的自定义对象

Object 形式自定义对象

//对象的定义
var 变量名 = new Object(); //对象实例(空对象)
变量名.属性名 =;		//定义一个属性
变量名.函数名 = function(){}  //定义函数

//对象的访问
变量名.属性名;
变量名.函数名();

var obj = new Object();
// alert(typeof(obj));//object
obj.name = "张三";
obj.age = 23;
obj.fun = function(){
	alert(this.age + "岁法外狂徒" + this.name )
}
			
obj.fun();

{}花括号形式的自定义对象

//对象的定义:
var 变量名 = { //定义一个对象
	属性名:值,		//定义一个属性(属性和函数之间都使用逗号分隔,最后一个不用)
	属性名:值,
	函数名: function(){}	//定义一个函数
};
var obj={};
alert(typeof(obj));//object

//对象的访问
变量名.属性;
变量名.函数名();

var obj ={
	name:"张三",
	age:23,
	fun:function(){
		alert(this.age + "岁法外狂徒" + this.name)
	}
}
alert(obj.name);
obj.fun();

JavaScript中的事件

什么是事件?事件是电脑输入设备与页面进行交互的响应。我们称之为事件。(划过、点击、输入等)

常用的事件:
onload 加载完成事件: 页面加载完成之后,常用于做页面 js 代码初始化操作
onclick 单击事件: 常用于按钮的点击响应操作。
onblur 失去焦点事件: 常用用于输入框失去焦点后验证其输入内容是否合法。
onchange 内容发生改变事件: 常用于下拉列表和输入框内容发生改变后操作
onsubmit 表单提交事件: 常用于表单提交前,验证所有表单项是否合法。

事件的注册又分为静态注册和动态注册两种:
什么是事件的注册(绑定)?
其实就是告诉浏览器,当事件响应后要执行哪些操作代码,叫事件注册或事件绑定。

静态注册事件: 通过 html 标签的事件属性直接赋于事件响应后的代码,这种方式我们叫静态注册。

动态注册事件: 是指先通过 js 代码得到标签的 dom 对象,然后再通过 dom 对象.事件名 = function(){} 这种形式赋于事件响应后的代码,叫动态注册。

动态注册基本步骤:

1、获取标签对象
2、标签对象.事件名 = fucntion(){}
onload 加载完成事件

onload 加载完成事件: 页面加载完成之后,常用于做页面 js 代码初始化操作
静态onload事件

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			function onloadfunc(){
				alert("静态注册onload事件,所有代码");
			}
		</script>
	</head>
	<!-- 静态注册onload事件 
			onload事件是浏览器解析完页面之后就会自动触发的事件
			为了代码的可读性,一般情况下只会在body标签内写一句代码,
			所有可以将需要的操作封装在一个函数内。
	-->
	<!-- <body οnlοad="alert('静态注册onload')"> -->
	<body onload="onloadfunc();">
		
	</body>
</html>

动态onload事件

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			//onload事件动态注册是固定写法
			window.onload = function(){
				alert("动态注册的onload事件")
			}
		</script>
	</head>
	<body>
	</body>
</html>
onclick 单击事件

onclick 单击事件: 常用于按钮的点击响应操作

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			function onclickfunc(){
				alert("静态注册onlick事件")
			}
			
			//动态输出onclick事件
			window.onload = function(){
				//1、获取标签对象
				/* document 是javaScript语言提供的一个对象(文档,表示整个页面内所有的内容)
				getElementById:通过Id属性获取标签(元素)对象
				*/
				var btnobj = document.getElementById("btn02");
				// alert(btnobj);//[object HTMLButtonElement]
				//2、通过标签对象.事件名 = function(){}
				btnobj.onclick = function(){
					alert("动态注册的onclick事件");
				}
			}
		</script>
	</head>
	<body>
		<!-- 静态注册onclick事件 -->
		<button onclick="onclickfunc()">按钮1</button><!--此时点击按钮1有反应-->
		<button id="btn02">按钮2</button>
	</body>
</html>
onblur 失去焦点事件

onblur 失去焦点事件: 常用用于输入框失去焦点后验证其输入内容是否合法。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
		// 静态注册失去焦点事件
			function onblurfun(){
				// console是控制台对象,是由JavaScript语言提供,专门用来向浏览器的控制器打印输出,用于测试使用。
				//log是打印的方法
				console.log("静态注册失去焦点事件");
			}
			
			// 动态注册失去焦点事件
			window.onload = function(){
				//1、获取标签对象
				var passwordobj = document.getElementById("password");
				// 通过标签对象.事件名 = function(){}
				passwordobj.onblur = function(){
					console.log("动态注册失去焦点事件");
				}
			}
		</script>
	</head>
	<body>
		用户名:<input type="text" onblur="onblurfun();" /><br />
		密码:<input type="text" id="password" /><br />
	</body>
</html>

在这里插入图片描述

onchange 内容发生改变事件

onchange 内容发生改变事件: 常用于下拉列表和输入框内容发生改变后操作

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			function onchangeFun(){
				alert("你变心了")
			}
			
			// 动态注册onchange事件
			window.onload = function(){
				//1、获取标签对象
				var selObj = document.getElementById("select02");
				 通过标签对象.事件名 = function(){}
				selObj.onchange =function(){
					alert("心中的男神已变");
				}
			}
		</script>
	</head>
	<body>
		请选择你心中的女神:
		<!-- 静态注册onchange事件 -->
		<select onchange="onchangeFun();">
			<option >--女神--</option>
			<option >--小芳--</option>
			<option >--小红--</option>
			<option >--佳佳--</option>
			<option >--小兰--</option>
			<option >--小雅--</option>
		</select>
		<br />
		请选择你心中的男神:
		<select id="select02">
			<option >--男神--</option>
			<option >--小明--</option>
			<option >--李华--</option>
			<option >--张三--</option>
			<option >--李四--</option>
			<option >--王五--</option>
		</select>
	</body>
</html>
onsubmit 表单提交事件

onsubmit 表单提交事件: 常用于表单提交前,验证所有表单项是否合法。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
		// 静态注册表单提交事件
			function onsubmitFun(){
				//验证所有表单项是否合法,如果有一个不合法就阻止表单提交
				alert("静态注册表单提交事件----发现不合法");
				return false;
				//静态页面阻止提交时的 return 不能少
			}
			
			// 动态注册表单提交事务
			window.onload = function(){
				//1、获取标签对象
				var formObj = document.getElementById("form01");
				// alert(formObj);//[object HTMLFormElement]
				//2、通过标签对象.事件名 = function(){}
				formObj.onsubmit = function(){
					alert("动态注册表单提交.....发现不合法");
					return false;
				}
			}
		</script>
	</head>
	<body>
		<!-- <form action="http://localhost:8080" method="get" οnsubmit="return false;" > -->
			<!-- return false;可以阻止表单提交 -->
			
		<form action="http://localhost:8080" method="get" onsubmit="return onsubmitFun();" >
			<input type="submit" value="静态注册"/>
		</form>
		
		<form action="http://localhost:8080" method="get" id="form01">
			<input type="submit" value="动态注册"/>
		</form>
	</body>
</html>

DOM模型

详细请看这里
DOM 全称是 Document Object Model 文档对象模型。

大白话,就是把文档中(html页面)的标签,属性,文本,转换成为对象来管理。
那么 它们是如何实现把标签,属性,文本转换成为对象来管理呢。这就是我们马上要学习的重点。

Document对象

Document 对象表示整个HTML文档,可用来访问页面中的所有元素。
Document 对象是 Window 对象的一部分,可通过 window.document 属性来访问
在这里插入图片描述

Document 对象的理解:
	第一点:Document 它管理了所有的 HTML 文档内容。
	第二点:document 它是一种树结构的文档。有层级关系。
	第三点:它让我们把所有的标签 都 对象化
	第四点:我们可以通过 document 访问所有的标签对象

什么是对象化??
我们基础班已经学过面向对象。请问什么是对象化?
举例:
有一个人有年龄:18 岁,性别:女,名字:张某某
我们要把这个人的信息对象化怎么办!
Class Person {
	private int age;
	private String sex;
	private String name;
}

那么 html 标签 要 对象化 怎么办?
<body>
<div id="div01">div01</div>
</body>
模拟对象化,相当于:
class Dom{
private String id; // id 属性
private String tagName; //表示标签名
private Dom parentNode; //父亲
private List<Dom> children; // 孩子结点
private String innerHTML; // 起始标签和结束标签中间的内容
}
Document 对象中的方法介绍(*****重点)
document.getElementById(elementId)
通过标签的 id 属性查找标签 dom 对象,elementId 是标签的 id 属性值

document.getElementsByName(elementName)
通过标签的 name 属性查找标签 dom 对象,elementName 标签的 name 属性值

document.getElementsByTagName(tagname)
通过标签名查找标签 dom 对象。tagname 是标签名

document.createElement( tagName)
方法,通过给定的标签名,创建一个标签对象。tagName 是要创建的标签

注:
document 对象的三个查询方法,如果有 id 属性,优先使用 getElementById 方法来进行查询
如果没有 id 属性,则优先使用 getElementsByName 方法来进行查询
如果 id 属性和 name 属性都没有最后再按标签名查 getElementsByTagName
以上三个方法,一定要在页面加载完成之后执行,才能查询到标签对象。
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			//需求:当用户点击了‘校验’按钮,要获取输入框里的内容,验证其是否合法
			//验证的规则是,必须由字母,数字,下划线组成,并且长度是5-12位。
			
			function onclickFun(){
				//1、当要操作一个标签的时候,一定要获取标签的对象
				var userNameObj = document.getElementById("userName");
				
				// alert(userNameObj);//[object HTMLInputElement]	它就是 dom 对象,可以获取标签的所有内容
				// alert(userNameObj.id);//userName
				// alert(userNameObj.type);//text
				// alert(userNameObj.value);//获取输入框的内容
				var userNameText = userNameObj.value;
				// alert(userNameText);
				//如何 验证 字符串 符合某些规则 , 需要使用正则表达式技术
				var patt = /^\w{5,12}$/;//验证的规则是,必须由字母,数字,下划线组成,并且长度是5-12位
				//test方法用于测试某个字符串是否匹配规则,匹配为true,不匹配为false
				if(patt.test(userNameText)){
					alert("用户名合法"+userNameText);
				}else{
					alert("用户名不合法"+userNameText);
				}
			}
		</script>
	</head>
	<body>
		用户名:<input type="text" id="userName"/>
		<button onclick="onclickFun()">校验</button>
	</body>
</html>

正则表达式

JavaScript RegExp对象|菜鸟教程
正则表达式用于对字符串模式匹配及检索替换,是对字符串执行模式匹配的强大工具。

语法
var patt=new RegExp(pattern,modifiers);
或者更简单的方式:

var patt=/pattern/modifiers;
pattern(模式) 描述了表达式的模式
modifiers(修饰符) 用于指定全局匹配、区分大小写的匹配和多行匹配

如:
// var patt = /^\w{5,12}$/;
// var patt=new RegExp("e");//表示要求字符串中包含字母e
var patt=/e/;//与上面效果相同,也是正则表达式,只是写法不一样。

// var str = "abcd";
// alert(patt.test(str));//false
var str = "abcde";
// alert(patt.test(str));//true
alert(patt);//  /e/
方括号

方括号用于查找某个范围内的字符:

表达式		描述
[abc]		查找方括号之间的任意一个字符。
[^abc]		查找任何不在方括号之间的字符。
[0-9]		查找任何从 09 的数字。
[a-z]		查找任何从小写 a 到小写 z 的字符。
[A-Z]		查找任何从大写 A 到大写 Z 的字符。
[A-z]		查找任何从大写 A 到小写 z 的字符。
[adgk]		查找给定集合内的任何字符。
[^adgk]		查找给定集合外的任何字符。
(red|blue|green)	查找任何指定的选项。

举例:

var patt=/[abc]/;
var str1="fast";
var str2="lsp";
alert(patt.test(str1));//true
alert(patt.test(str2));//false
元字符

元字符(Metacharacter)是拥有特殊含义的字符

元字符		描述
.		查找单个字符,除了换行和行结束符。
\w		查找数字、字母及下划线。(查找单词字符,是否大写字母、小写字母,数字和下划线)
\W		查找非单词字符。
\d		查找数字。
\D		查找非数字字符。
\s		查找空白字符。
\S		查找非空白字符。
\b		匹配单词边界。
\B		匹配非单词边界。
\0		查找 NULL 字符。
\n		查找换行符。
\f		查找换页符。
\r		查找回车符。
\t		查找制表符。
\v		查找垂直制表符。
\xxx	查找以八进制数 xxx 规定的字符。
\xdd	查找以十六进制数 dd 规定的字符。
\uxxxx	查找以十六进制数 xxxx 规定的 Unicode 字符。

举例:

var patt=/\w/;
var str="【【【";
alert(patt.test(str));
量词
量词				描述
n+			匹配任何包含至少一个 n 的字符串。
例如,/a+/ 匹配 "candy" 中的 "a""caaaaaaandy" 中所有的 "a"。


n*			匹配任何包含零个或多个 n 的字符串。
例如,/bo*/ 匹配 "A ghost booooed" 中的 "boooo""A bird warbled" 中的 "b",但是不匹配 "A goat grunted"。


n?			匹配任何包含零个或一个 n 的字符串。
例如,/e?le?/ 匹配 "angel" 中的 "el""angle" 中的 "le"。


n{X}		匹配包含 X 个 n 的序列的字符串。
例如,/a{2}/ 不匹配 "candy," 中的 "a",但是匹配 "caandy," 中的两个 "a",且匹配 "caaandy." 中的前两个 "a"。


n{X,}		X 是一个正整数。前面的模式 n 连续出现至少 X 次时匹配。
例如,/a{2,}/ 不匹配 "candy" 中的 "a",但是匹配 "caandy""caaaaaaandy." 中所有的 "a"。


n{X,Y}		XY 为正整数。前面的模式 n 连续出现至少 X 次,至多 Y 次时匹配。
例如,/a{1,3}/ 不匹配 "cndy",匹配 "candy," 中的 "a""caandy," 中的两个 "a",匹配 "caaaaaaandy" 中的前面三个 "a"。注意,当匹配 "caaaaaaandy" 时,即使原始字符串拥有更多的 "a",匹配项也是 "aaa"。

n$			匹配任何结尾为 n 的字符串。
^n			匹配任何开头为 n 的字符串。
?=n			匹配任何其后紧接指定字符串 n 的字符串。
?!n			匹配任何其后没有紧接指定字符串 n 的字符串。

举例:

var patt=/a+/;//表示字符串中是否至少包含一个a
var str1= "a"
var str2="aaaabbbccc"
alert(patt.test(str1));//true
alert(patt.test(str2));//true

var patt=/a*/;//表示字符串中是否包含0个a或多个a
var str1= "a"
var str2="aaaabbbccc"
alert(patt.test(str1));//true
alert(patt.test(str2));//true

var patt = /a?/;//表示是否包含0个或1个n
var str1 = "aa";
var str2 = "a";
var str3 = "bcd";
alert(patt.test(str1));//true
alert(patt.test(str2));//true
alert(patt.test(str3));//true

var patt = /a{3}/;//表示是否包含连续三个a
var str1 = "123aaa456";
var str2 = "a";
var str3 = "bcd";
alert(patt.test(str1));//true
alert(patt.test(str2));//false
alert(patt.test(str3));//false

var patt = /a{3,5}/;//表示是否包含连续三个a(此时的5没有什么作用,以为还是包含三个连续的a)
var str1 = "123aaa456";
var str2 = "123aaaaa";
var str3 = "aaaaaabcd";
alert(patt.test(str1));//true
alert(patt.test(str2));//true
alert(patt.test(str3));//true
//包含表示最小条件满足,只要满足最小条件就行

var patt = /a$/;//表示字符串必须以a结尾
var str1 = "123aaa456";
var str2 = "123aaaaa";
var str3 = "aaaaaabcd";
alert(patt.test(str1));//false
alert(patt.test(str2));//true
alert(patt.test(str3));//false
    
var patt = /^a/;//表示字符串必须以a开头
var str1 = "123aaa456";
var str2 = "123aaaaa";
var str3 = "aaaaaabcd";
alert(patt.test(str1));//false
alert(patt.test(str2));//false
alert(patt.test(str3));//true


// var patt=/^a{3,5}$/;//只检查一部分,满足条件即可
		
var patt=/^a{3,5}$/;// 要求字符串从头到尾要完全匹配()从头到尾检查
var str1 = "aaaaaa";
var str2 = "aaaaa";
alert(patt.test(str1));//false
alert(patt.test(str2));//true

var patt=/^\w{6,16}$/;//表示必须是数字字母下划线长度为6-16

两种常见的验证提示效果

方式一:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			
			function onclickFun(){
				var userNameObj = document.getElementById("userName");
				var userNameText = userNameObj.value;
				
				var patt=/^\w{5,12}$/;
				// alert(userNameText
				
				var userNameSpanObj = document.getElementById("userNameSpan");
				//innerHTML 表示起始标签和结束标签中的内容
				// innerHTML 这个属性可读可写
				// alert(userNameSpanObj.innerHTML);
				if(patt.test(userNameText)){
					userNameSpanObj.innerHTML="用户输入合法";
				}else{
					userNameSpanObj.innerHTML="用户输入不合法";
				}
			}
		</script>
	</head>
	<body>
		<input type="text" id="userName" />
		<span id="userNameSpan" style="color: red;"></span>
		<button type="button" onclick="onclickFun();">校验</button>
	</body>
</html>

在这里插入图片描述
在这里插入图片描述
方式二:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
		
			function onbulurFun(){
				var userNameObj = document.getElementById("userName");
				var userNameSpan = document.getElementById("userNameSpan");
				var patt = /^\w{5,12}$/;
				var userNameText = userNameObj.value;
				if(patt.test(userNameText)){
					userNameSpan.innerHTML = "<img src='imgs/right.png' width='20px' />"
				}else{
					userNameSpan.innerHTML = "<img src='imgs/wrong.png' width='20px' />"
				}
			}
		</script>
	</head>
	<body>
		<input type="text" id="userName" onblur="onbulurFun()";/>
		<span id="userNameSpan"></span>
		<!-- <button type="button" ">校验</button> -->
	</body>
</html>

在这里插入图片描述
在这里插入图片描述

getElementByName方法

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			function checkAll(){//全选
				//让所有复选框都选中
				//document.getElementsByName():根据指定的name属性查询返回多个标签对象集合,这个集合操作跟数组一样。
				//集合中每个元素都是dom对象
				//这个集合中的顺序就是他们在html页面中从上到下的顺序
				var hobbies = document.getElementsByName("hobby");
				// alert(hobbies);//[object NodeList]
				// alert(hobbies.length);//3
				//alert(hobbies[0].value);//java
				// checked 表示复选框的选中状态,如果选中是true,如果不选是false
				//这个属性 可读可写
				// alert(hobbies[0].checked);//true
				// alert(hobbies[1].checked);//false
				// hobbies[1].checked=true;//修改cpp的选中状态
				// alert(hobbies[1].checked);
				for (var i = 0; i < hobbies.length; i++) {
					hobbies[i].checked = true;
				}
			}
			function checkNo(){//全不选
			var hobbies = document.getElementsByName("hobby");
				for (var i = 0; i < hobbies.length; i++) {
					hobbies[i].checked = false;
				}
			}
			function checkReverse(){//反选
				var hobbies = document.getElementsByName("hobby");
				for (var i = 0; i < hobbies.length; i++) {
					// if(hobbies[i].checked == false){
					// 	hobbies[i].checked = true;
					// }else{
					// 	hobbies[i].checked = false;
					// }
					hobbies[i].checked = !hobbies[i].checked;
				}
			}
		</script>
	</head>
	<body>
		兴趣爱好:
		<input type="checkbox" name="hobby" id="" value="java">java
		<input type="checkbox" name="hobby" id="" value="cpp" />C++
		<input type="checkbox" name="hobby" id="" value="python" />python
		<br>
		<button onclick="checkAll();">全选</button>
		<button onclick="checkNo();">全不选</button>
		<button onclick="checkReverse()">反选</button>
	</body>
</html>

getElementByTagName方法

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			function checkAll(){
				//getElementsByTagName():按照指定的标签名来进行查询,并返回集合
				// 这个集合的操作和数组的一样,集合中都是dom对象,
				// 集合中的顺序是他们在html页面中从上到下的顺序
				var inputs = document.getElementsByTagName("input");
				// alert(inputs);//[object HTMLCollection]
				for (var i = 0; i < inputs.length; i++) {
					inputs[i].checked = true;
				}
			}
		</script>
	</head>
	<body>
		兴趣爱好:
		<input type="checkbox" id="" value="java">java
		<input type="checkbox" id="" value="cpp" />C++
		<input type="checkbox" id="" value="python" />python
		<br>
		<button onclick="checkAll();">全选</button>
	</body>
</html>

document对象三个查询方法的使用注意事项

document对象的三个查询方法,如果有id属性,优先使用getElementById方法来进行查询
如果没有id属性,则优先使用getElementByName方法来进行查询
如果id属性和name属性都没有,最后再按标签名查getElementByTagName.

以上三个方法,一定要在页面加载完成之后执行,才能查询到标签对象。

节点的常用属性和方法

节点就是标签对象

方法:
通过具体的元素节点调用
getElementsByTagName()
方法,获取当前节点的指定标签名孩子节点
appendChild( oChildNode )
方法,可以添加一个子节点,oChildNode 是要添加的孩子节
属性:
childNodes		属性,获取当前节点的所有子节点
firstChild		属性,获取当前节点的第一个子节点
lastChild		属性,获取当前节点的最后一个子节点
parentNode		属性,获取当前节点的父节点
nextSibling		属性,获取当前节点的下一个节点
previousSibling	属性,获取当前节点的上一个节点
className		用于获取或设置标签的 class 属性值
innerHTML		属性,表示获取/设置起始标签和结束标签中的内容
innerText		属性,表示获取/设置起始标签和结束标签中的文本

举例如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>dom查询</title>
<link rel="stylesheet" type="text/css" href="style/css.css" />
<script type="text/javascript">
	window.onload = function(){
		//1.查找#bj节点
		document.getElementById("btn01").onclick = function(){
			var bjObj = document.getElementById("bj");
			alert(bjObj.innerHTML);//北京
		}
		//2.查找所有li节点
		var btn02Ele = document.getElementById("btn02");
		
		btn02Ele.onclick = function(){
			var lis = document.getElementsByTagName("li");
			alert(lis.length);//11
		};
		//3.查找name=gender的所有节点
		var btn03Ele = document.getElementById("btn03");
		btn03Ele.onclick = function(){
			var genders = document.getElementsByName("gender");
			alert(genders.length);
		};
		//4.查找#city下所有li节点
		var btn04Ele = document.getElementById("btn04");
		btn04Ele.onclick = function(){
			//1、获取id为city的节点
			// 2、通过city节点.getElementByTagName
			var lis = document.getElementById("city").getElementsByTagName("li");
			alert(lis.length);
			
		};
		//5.返回#city的所有子节点
		var btn05Ele = document.getElementById("btn05");
		btn05Ele.onclick = function(){
			//1、获取id为city的节点
			// 2、通过city节点获取所有子节点
			alert(document.getElementById("city").childNodes.length);//一个空格一个字符串都是子节点
		};
		//6.返回#phone的第一个子节点
		var btn06Ele = document.getElementById("btn06");
		btn06Ele.onclick = function(){
			//查找id为phone的节点
			//实现firstChild
			alert(document.getElementById("phone").firstChild.innerHTML);
		};
		//7.返回#bj的父节点
		var btn07Ele = document.getElementById("btn07");
		btn07Ele.onclick = function(){
			//查找id为bj的节点
			//通过bj节点查找父节点
			alert(document.getElementById("bj").parentNode.innerHTML);
		};
		//8.返回#android的前一个兄弟节点
		var btn08Ele = document.getElementById("btn08");
		btn08Ele.onclick = function(){
			// 1、获取id为android的节点
			// 2、通过android节点获取前面兄弟节点
			alert(document.getElementById("android").previousSibling.innerHTML);
			
		};
		//9.读取#username的value属性值
		var btn09Ele = document.getElementById("btn09");
		btn09Ele.onclick = function(){
			alert(document.getElementById("username").value);
		};
		//10.设置#username的value属性值
		var btn10Ele = document.getElementById("btn10");
		btn10Ele.onclick = function(){
			document.getElementById("username").value = "张三";
		};
		//11.返回#bj的文本值
		var btn11Ele = document.getElementById("btn11");
		btn11Ele.onclick = function(){
			alert(document.getElementById("bj").innerHTML);//内容
			alert(document.getElementById("bj").innerText);//文本(不要标签)
		};
	};
</script>
</head>
<body>
<div id="total">
	<div class="inner">
		<p>
			你喜欢哪个城市?
		</p>

		<ul id="city">
			<li id="bj">北京</li>
			<li>上海</li>
			<li>东京</li>
			<li>首尔</li>
		</ul>

		<br>
		<br>

		<p>
			你喜欢哪款单机游戏?
		</p>

		<ul id="game">
			<li id="rl">红警</li>
			<li>实况</li>
			<li>极品飞车</li>
			<li>魔兽</li>
		</ul>

		<br />
		<br />

		<p>
			你手机的操作系统是?
		</p>

		<ul id="phone"><li>IOS</li><li id="android">Android</li><li>Windows Phone</li></ul>
	</div>

	<div class="inner">
		gender:
		<input type="radio" name="gender" value="male"/>
		Male
		<input type="radio" name="gender" value="female"/>
		Female
		<br>
		<br>
		name:
		<input type="text" name="name" id="username" value="abcde"/>
	</div>
</div>
<div id="btnList">
	<div><button id="btn01">查找#bj节点</button></div>
	<div><button id="btn02">查找所有li节点</button></div>
	<div><button id="btn03">查找name=gender的所有节点</button></div>
	<div><button id="btn04">查找#city下所有li节点</button></div>
	<div><button id="btn05">返回#city的所有子节点</button></div>
	<div><button id="btn06">返回#phone的第一个子节点</button></div>
	<div><button id="btn07">返回#bj的父节点</button></div>
	<div><button id="btn08">返回#android的前一个兄弟节点</button></div>
	<div><button id="btn09">返回#username的value属性值</button></div>
	<div><button id="btn10">设置#username的value属性值</button></div>
	<div><button id="btn11">返回#bj的文本值</button></div>
</div>
</body>
</html>
@CHARSET "UTF-8";

body {
	width: 800px;
	margin-left: auto;
	margin-right: auto;
}

button {
	width: 300px;
	margin-bottom: 10px;
}

#btnList {
	float:left;
}

#total{
	width: 450px;
	float:left;
}

ul{
	list-style-type: none;
	margin: 0px;
	padding: 0px;
}

.inner li{
	border-style: solid;
	border-width: 1px;
	padding: 5px;
	margin: 5px;
	background-color: #99ff99;
	float:left;
}

.inner{
	width:400px;
	border-style: solid;
	border-width: 1px;
	margin-bottom: 10px;
	padding: 10px;
	float: left;
}

在这里插入图片描述

对document对象的补充说明

document.createElement();//创建标签对象
document.body.appendChild();//向body标签添加子元素

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
		window.onload = function(){
			// 现在需要使用js代码,来创建html标签,显示在页面上
			// 标签的内容就是:<div>张三</div>
			var divObj = document.createElement("div");//在内存中<div></div>
			// alert(divObj);//[object HTMLDivElement]
			divObj.innerHTML = "张三";//<div>张三</div>,在网页中没有显示
			// 添加子元素
			document.body.appendChild(divObj);
		}
		</script>
	</head>
	<body>
		
	</body>
</html>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值