文章目录

  • 一、JavaScript的组成
  • 二、JavaScript的引入
  • 三、JavaScript的语法规范
  • 1. 注释
  • 2. 变量
  • 1. 变量的声明:
  • 2. 变量的声明和赋值
  • 3. 变量的类型:
  • 3. 运算符
  • 1. 比较运算符:
  • 2. 逻辑运算符: &&(与) ||(或) !(非)
  • 4. 正则对象
  • 1. ReqExp对象的创建方式
  • 2. ReqExp 对象方法
  • 3. 正则对象使用注意事项
  • 5. JS数组对象
  • 1. JS数组的特性: JS数组可以看出Java中ArrayList集合
  • 2. JS数组的四种创建方式
  • 3. JS数组的常用属性/方法
  • 6. 全局函数
  • 1. 执行
  • 2. 编码和解码
  • 3. URI与URL的区别
  • 4. 字符串转数字
  • 7. 自定义函数
  • 1. 函数的格式:
  • 2. 自定义函数注意事项
  • 8. 自定义对象
  • 1. 利用function函数 创建对象
  • 2. 对象的直接量 (Json形式)
  • 四、BOM对象
  • 1. BOM对象是什么有什么作用
  • 2. 消息框
  • 3. 定时器
  • 1. 循环定时器的设置和取消
  • 2. 一次定时器的设置和取消
  • 4. location对象
  • 1. location对象的属性:
  • 五、 DOM对象
  • 1. DOM对象是什么有什么作用?
  • 2. DOM树介绍
  • 3. 获取元素节点对象
  • 4. 元素对象常见属性值
  • 六、JS事件
  • 1. JS事件是什么?有什么作用
  • 2. JS事件驱动机制
  • 3.常见JS事件
  • 1. 点击事件
  • 2. 焦点事件
  • 3. 域内容改变事件
  • 4. 加载完毕事件(用的多)
  • 5. 表单提交事件 (一般用于表单校验)
  • 6. 键位弹起事件
  • 7. 鼠标事件
  • 4. JS事件两种绑定方式
  • 1. 事件句柄绑定:
  • 2. DOM绑定方式: 使用DOM相应属性曲绑定事件
  • DOM绑定的优缺点


一、JavaScript的组成

  1. ECMAScript:(核心)规定Js语法和基本对象
  2. DOM: 文档对象模型 处理网页内容的方法和接口 标记型文档 html 操作文档元素
  3. BOM: 浏览器对象,操作浏览器

二、JavaScript的引入

  1. 内部脚本方式
<script type = "text/javascript">       //type 可省略
        //Js脚本内容 从上到下顺序执行
    </scrpit>
   <!-- 理论上可以放在任何地方-->
  1. 放在外部文件任何html都可以引用
<script type = "text/javascript" src = "js路径">
        //里面不写代码, 不会执行
    </script>

三、JavaScript的语法规范

1. 注释

  • 单行注释: //
  • 多行注释:/**/

2. 变量

1. 变量的声明:

var 变量名; (未赋值的默认值 undefined)

2. 变量的声明和赋值

var 变量名 = 值;

3. 变量的类型:

1.基本数据类型:

  1. string: 字符串类型 “” 与’’ 都表示字符串
  2. boolean: 布尔类型 true false
  3. number: 数字类型 任意数字
  4. null: 空 一个占位符
  5. undefined: 未定义类型 只有一个固定值undefined

由于JavaScript是弱类型语言,看变量类型的时候不能一下子看出来,用typeof运算符可以判断变量的类型

var str = 1; str = true; str = null; //一个变量只要被声明出来可以赋值任何类型
用typeof运算符可以判断 一个变量类型 typeof(str) 但是有一个bug typeof(null) == object

2.引用数据类型:
通常叫做类class, 但是javascript没有编译过程,所以没有类的概念

标志创建方式:
var str = new String();
var str = new String; js独有

3. 运算符

1. 比较运算符:
  1. ===(比较具体值和类型) str1 = 10; str2 = “10”; 结果false
  2. == (比较具体值) str1 = 10; str2 = “10”; 结果true
    其他都和Java一样
2. 逻辑运算符: &&(与) ||(或) !(非)

4. 正则对象

1. ReqExp对象的创建方式
var reg = new RegExp("表达式");     //基本开发不用
 var reg = /^表达式$/                    //直接量(开发常用)
                                       // ^开始   $结束       是正则对象
2. ReqExp 对象方法

test(字符串); //如果字符串全部字符符合正则表达式返回true 否则 false

3. 正则对象使用注意事项

/^表达式$/ 只有一个字符不符合就 false 全部符合才是true( 用于表单校验)

/表达式/ 只要有一个字符符合就为true 全部符合才为false

5. JS数组对象

1. JS数组的特性: JS数组可以看出Java中ArrayList集合

数组中每一个成员的类型没有限制且数组的长度可以任意修改

2. JS数组的四种创建方式
  1. var arr = [1,2,3,“a”,true]; //常用的JS数组
  2. var arr = new Array(); //创建JS数组,默认长度为0 1 2 常用
  3. var arr = new Array(); //创建JS数组,默认长度为4
  4. var arr = new Array(“1”,ture); //创建JS数组 初始化
3. JS数组的常用属性/方法
  1. 属性: length: 数组长度
  2. 方法:
  • join(string): 可以将数组每个元素根据string给出字符连接每个数组元素 对原先数组不影响
  • reverse(): 将数组元素反转
  • push(): 往数组尾添加元素并且 返回新的长度
  • pop(): 删除并返回数组最后一个元素

6. 全局函数

1. 执行

eval(string)函数: 把传进去的字符串当作脚本代码执行 这个字符串只能是基本数据类型字符串string还可以把JSON字符串转化为对象

2. 编码和解码

URL/URI编码: 中文及特殊符号 16进制
作用: 保证数据传递的完整性

  • encodeURI(string) 把字符串编码尾URI
  • decodeURI(string) 解码某个编码URI
3. URI与URL的区别

URL: 统一资源定位器(包含http://), 定位网络资源的位置
URI: 统一资源标识符(包含资源名 ), 标识详细的网络名称

例如:

4. 字符串转数字

1 parseInt(string) 解析字符串返回一个整数 (小数部分直接舍弃)

2 parseFloat(string) 解析一个字符串返回一个浮点数 (如果碰到无法解析的数字 直接停止 parseFloat(“11.5a5”) == 11.5

注:如果第一位就不符合直接返回 NAN(不是一个数字)
NAN是一个数字标识 不是一个数字(Not A Number)

7. 自定义函数

1. 函数的格式:

function 方法名(参数列表){
函数体;
}
注意:

  • 参数的定义无需var关键字, 直接使用
  • javascript的函数体, return可以写, 也可以不写, 可以写return的值也可以return;
  • 不写return的返回值是undefined

例如:

function getSum(a,b){
				return a + b;
			}
2. 自定义函数注意事项
  • javascript中没有重载,只有方法覆盖,最后定义的重名函数会覆盖掉前面的函数
  • 既是实参与函数的形参不匹配,也不影响正常使用
  • 如果形参为赋值,就会使用默认的undefined

8. 自定义对象

1. 利用function函数 创建对象

无参数格式
function 对象名(){
函数体;
}
例子:

//声明了一个对象
				function Person(){
					
				}
				//创建了Person对象
				var p = new Person();
				alert(p);		//出现	[object Object]	创建成功

this代表当前类对象 Person

function Person(){
			this.name = "小芳";
			this,age = 18;
		}
		
		var p = new Person();
		alert(p.name);
		alert(p.age);

为属性赋值方式

//1. 构造参数赋值
		function Person(a,b){
			this.age = a;
			this.name = b;
		}
		var p = new Person(17,"小芳");
		
		//2. 调用对象的属性赋值
		function Person(a,b){
			this.age = a;
			this.name = b;
		}
		var p = new Person(17,"小芳");
		p.name = "小李";
2. 对象的直接量 (Json形式)

格式: var 对象名 = {属性名1:“属性值1”, 属性名2,“属性值2”,…}; 直接 把对象创建出来了 不需要在new对象

创建初始化创建属性和属性值

var p = {name:"小芳", age:12};
	alert(p.name + "-------" + p.age)
	p.name = "小王吧";
	alert(p.name);

四、BOM对象

1. BOM对象是什么有什么作用

BOM(Browser Object Model) 浏览器对象模型

作用:用来执行浏览器相关的操作(例如:浏览器的地址栏, 弹出消息)

一般情况下,window代表了BOM对象

注意:windo对象是Javascript的内置对象,适用window对象调用方法、属性的时候可以省略window不写
(比如alert()是window的方法 但是都是直接写 alert())


2. 消息框

  1. alert(); 弹出警告框
  2. boolbean confirm(); 确认框 (显示确定 取消)

有一个返回值 当点确定的时候返回true 取消返回false

var b = confirm("你好");
			alert(b);

3. 定时器

1. 循环定时器的设置和取消

1.启动循环定时器:
setInterval(“调用方法”,毫秒值); 每过多少毫秒调用一次参数(方法) 返回值是一个id)( 通常提醒用户做什么事情)

function run1(){
						alert("run1");
					}
					setInterval("run1()", 2000);

2.取消循环定时器
clearInterval(循环定时器的id);

function run1(){
						alert("run1");
					}
					
					var id = setInterval("run1()", 2000);
					
					clearInterval(id);


2. 一次定时器的设置和取消

1.启动一次性定时器
setTimeout(“调用方法”,毫秒数); 返回值是一个id 只提醒一次

2.取消一次定时器:
clearTimeout(id);

function run1(){
			alert("run1");
		}
		//启动一次定时器
		var id = setTimeout("run1()", 2000);

		//停止一次性定时器
		clearTimeout(id);


4. location对象

1. location对象的属性:

  1. href //当前浏览器地址栏的完整URL
var url = location.href;		//获取当前URL
		
		location.href = "";				//修改URL
小需求:两秒后跳转百度
function run(){
		location.href = "http://www.baidu.com";			//跳外网一定要写http://
	}
	
	setTimeout("run()",2000);

五、 DOM对象

1. DOM对象是什么有什么作用?

DOM(Document Object Model) 文档对象模型

DOM是将标记型文档中所有的内容(标签, 文本, 属性) 都封装成对象

通过操作DOM对象的属性或者方法,来达到控制或者改变HTML展示效果(特效)

2. DOM树介绍

javascript 初学者 javascript基础入门教程_javascript

<html>
				<head>
					<title>	文档标题</title>
				</head>
				
				<body>
					<a href = "">我的链接</a>
					<h1>我的标题</h1>
				</body>
			</html>

上述HTML文档被浏览器 由上到下依次解析, 加载加载到浏览器内存

其中:

  • 每个标签都会被加载成DOM树上的一个元素节点对象
  • 每个标签的属性都会被加载成DOM树上一个属性节点对象
  • 每个标签的内容都会被加载成DOM树上一个文本节点对象
  • 整个DOM树, 是一个文档节点对象,即DOM对象
  • 一个HTML文档加载到内存中就会形成一个DOM对象

DOM树的特点:

  • 每个节点都是节点对象
  • 常见的节点关系:父子节点关系
  • 文本节点对象没有子节点(本身是叶子节点)
  • 每一个节点都有父节点(除了根节点)

3. 获取元素节点对象

DOM对象 document.
获取元素节点对象的四个方法

  • getElementById() 通过id 获取对象 找不到返回null
  • getElementByName() 通过name获取所有符合元素对象
    返回对象数组 找不到返回空
  • getElementByTagName() 通过元素标签名获取所有符合的对象
    返回数组对象
  • getElementByClassName() 通过元素名class属性获取所有符合的对象
    返回数组对象
    注意:
    这边获取节点对象要放在最下面 防止前面的标签没有被加载到浏览器
<!DOCTYPE html>
		<html lang="en">
			<head>
				<meta charset="UTF-8">
				<title>获取元素节点对象</title>
			</head>
			<body>
				<input type="button" id = "iid" class="kike" name="kk"/>
				<input type="text" id = "lzj" class="kike" value="有钱"/>
				<input type="button" id = "sm" />
				<input type="button" id = "kkk"  name="kk"/>
				<ui>
					<li>lzj</li>
					<li>    </li>
				</ui>
				<script>
					var v = document.getElementById("lzj");
					alert(v);

					var arr = document.getElementsByClassName("kike");
					alert(arr.length);

					var arr1 = document.getElementsByName("kk");
					alert(arr1);

					var arr2 = document.getElementsByTagName("li");
					alert(arr2.length);
				</script>
			</body>
		</html>

4. 元素对象常见属性值

  1. value
    元素对象.value 获取元素对象value属性值
    元素对象.value=属性值 改变元素对象value属性值
  2. className
    元素对象.className 获取元素对象的class属性
    元素对象.className=属性值 设置对象的class属性值
<!DOCTYPE html>
<html lang="en">
	<head>
	   
		<title>元素对象常见属性</title> 
	</head>
	<body>
		<input type="text" id="t1" value="你好" class="kkk"/>
		<script>
			var d = document.getElementById("t1");
			alert(d.value +"----"+  d.id + "----"+d.type +"-----"+d.className);

			
		</script>

	</body>
</html>
  1. checked
    元素对象.checked 获取元素对象的checked属性值
    元素对象.checked 设置元素对象的checked属性值
    checked的属性值是true||false 标识单选框||复选框有无选中
<!DOCTYPE html>
	<html lang="en">
		<head>
		   
			<title>元素对象常见属性</title> 
		</head>
		<body>
		   
			<input type="checkbox" id="hobby" />
			<script>
			 

				var c=document.getElementById("hobby");
				alert(c.checked);
				c.checked=true;
				
			</script>

		</body>
	</html>
  1. innerHTML
    元素对象.innerHTML 获取元素对象innerHTML属性值 就是文本内容
    元素对象.innerHTML=“属性值” 设置元素对象的innerHTML属性值
<!DOCTYPE html>
	<html lang="en">
		<head>
		   
			<title>元素对象常见属性</title> 
		</head>
		<body>
		
			<span id="s1">今天天气真好</span>
			<script>
				var s = document.getElementById("s1");
				alert(s.innerHTML);
				s.innerHTML+= ",是啊 阳光明媚";
			</script>

		</body>
	</html>

六、JS事件

1. JS事件是什么?有什么作用

通常鼠标或者热键的动作我们称之为事件

点击、表单提交、值发生改变、鼠标移入、鼠标移出

通过JS事件,我们可以完成页面指定的特效

2. JS事件驱动机制

页面上面的特效,我们可以理解在JS事件驱动机制来进行如下
JS事件驱动机制:
事件源:
事件:
监听器:
注册监听器:

<!DOCTYPE html>
	<html lang="en">
		<head>
			<meta charset="UTF-8">
		 
			<title>事件驱动机制</title>
			<script>
				function run(){
					alert("run");
				}
			</script>
		</head>
		<body>
			<input type="button" id="click" onclick="run()" value="点我"/>
		</body>
	</html>

事件源:按钮
事件: 点击事件 onclick
监听器: run()方法
注册监听器:οnclick=“run()”

3.常见JS事件

1. 点击事件

οnclick=“需要执行方法” 来绑定 方法 一点击触发执行该函数

2. 焦点事件

聚集焦点事件:
onfoucus=“需要执行方法” 绑定方法 鼠标一点击某个地方 获取焦点

失去焦点事件: οnblur=“需要执行方法” 绑定方法 原本点着某个地方 当鼠标不点鼠标点击其他地方失去焦点

3. 域内容改变事件

οnchange=“需要执行方法” 值改变了就执行绑定方法

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<title>Document</title>
		<script>
			function run(){
				alert("值改变了");
			}
		</script>
	</head>
	<body>
		<select onchange="run()">
			<option>北京</option>
			<option>上海</option>
			<option>南京</option>
		</select>
	</body>
</html>
4. 加载完毕事件(用的多)

οnlοad=“需要执行方法” 加载完成后 触发绑定的放
例如body加载完成后弹出窗口

<script>
		function run(){
			alert("弹出");
		}
	<script>
	<body onload="run()">
	</body>
5. 表单提交事件 (一般用于表单校验)

οnsubmit=“需要执行方法” 表单提交后 触发绑定方法
如果要获取返回值 οnsubmit=“return 需要执行方法”; 如果οnsubmit=true; 允许表单提交 如果false阻止提交

6. 键位弹起事件

οnkeyup=“需要执行方法”

7. 鼠标事件

鼠标移入事件:οnmοuseοver=“需要执行方法”; 只要鼠标移入绑定的组件 就触发绑定方法

鼠标移出事件:οnmοuseοut=“需要执行方法” 只要鼠标溢出绑定组件 触发绑定方法

4. JS事件两种绑定方式

1. 事件句柄绑定:

将事件以属性的形式写到标签内部,进而绑定对应的函数

绑定一个方法

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
	   
		<title>Document</title>
		<script>
			function run(){
				alert("你好?");
			}
			function run1(a ){
				alert(a);
			}
			function run2(obj){
				alert(obj.value);
			}
		</script>
	</head>
	<body>
		<!-- 无参方法 -->
		<input type="text" value="1111" onclick="run()"><br>
		<!-- 有参方法 -->
		<input type="text" name="1111" id="1111" onclick="run1('你好')"><br>
		<!-- 有参方法   参数是对象 this代表本个标签元素对象 -->
		<input type="text" value="12345" onclick="run2(this)"><br>
	</body>
</html>

绑定多个方法

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
	   
		<title>Document</title>
		<script>
			function run(){
				alert("你好?");
			}
			function run1(){
				alert("aka");
			}
			function run2(){
				alert("skr");
			}
		</script>
	</head>
	<body>
		<!-- 执行的顺序就是绑定的顺序 -->
		<input type="text" value="1111" onclick="run(),run1(),run2()"><br>
		
	</body>
</html>

事件句柄绑定方式优缺点:
优点:
1. 开发快捷
2. 传参方便
3. 可以绑定多个函数

缺点: JS和HTML代码高度融合,不利于部门项目的维护 (耦合性太大)

2. DOM绑定方式: 使用DOM相应属性曲绑定事件

格式:

DOM对象.JS事件=方法名; (一次只能绑定一个方法)

//建议使用
DOM对象.JS事件=function(){
方法1();
方法2();
}
(绑定匿名方法,可以绑定多个方法函数 相当于Java中的匿名内部类,建议使用)

//当页面加载完调用
			window.onload=function(){
				run1();
				run2();
				run3();
			}
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<title>Document</title>
		<script>
			function run1(){
				alert("run1");
			}
			function run2(){
				alert("run2");
			}

			//由于页面是顺序执行的 只有页面加载完 通过id获取到节点元素对象
			window.onload=function(){
				var t1=document.getElementById("t1");
				t1.onclick=function(){
					run1();
					run2();
				}
			}
		</script>
	</head>
	<body>

		<!-- 
			为文本框    onclick事件绑定两个函数 run1()  run2()
		 -->
		<input type="text" id="t1">
	</body>
</html>
DOM绑定的优缺点

优点:使HTML和JS代码分离

缺点:不能传递参数 (已解决通过匿名函数可以 =function(a){})
一次只能绑定一个方法 (已解决通过匿名函数可以)