JavaScript

本文全面介绍了JavaScript,包括其简介、基本语法、内建对象、函数和事件等内容。阐述了JS的特点、引入方式,讲解了变量、数据类型、运算符等语法知识,介绍了各类内建对象的创建与使用,还说明了函数定义、参数、返回值及事件的绑定、阻止默认行为和传播等。

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

一、js的简介

1、js是什么

js是可以嵌入到html中,是 基于对象 和 事件驱动 的 脚本语言 。事件驱动:事件反馈(页面加载事件...)

特点:

(1)交互性

(2)安全性:js不能访问本地磁盘

(3)跨平台:浏览器中都具备js解析器

2、js能做什么

(1)js能动态的修改(增删)html和css的代码

(2)能动态的校验数据

3、js历史及组成

ECMAScript BOM(浏览器对象模型) DOM(文档对象模型)

4、js被引入的方式

(1)内嵌脚本

<input type="button" value="button" οnclick="alert('xxx')" />

(2)内部脚本

<script type="text/javascript">

alert("xxx");

</script>

(3)外部脚本

首先先创建一个js文件

其次在html中引入

<script type="text/javascript" src="demo1.js"></script>

js代码放在哪?

放在哪都行 但是在不影响html功能的前提下 越晚加载越好

二、js基本语法

1、变量

(1) 用var定义变量,放什么都行

var x = 5;

x = 'javascript';

var y = "hello";

var b = true;

(2) 弱类型,不使用var也可以

x = 5;

2、原始数据类型

(1)number:数字类型

(2)string:字符串类型

(3)boolean:布尔类型

(4)null:空类型

(5)underfind:未定义

注意:number、boolean、string是伪对象

类型转换:

number\boolean转成string var x=5,alert(typeof x.toString())

toString();

string\boolean转成number

parseInt()

parseFloat()

boolean不能转

string可以将数字字符串转换成number 如果“123a3sd5” 转成123

强制转换

Boolean() 强转成布尔

数字强转成布尔 非零就是true 零就是false

字符串强转成布尔 非“”(空字符串)就是true 空字符串“”就是false

Number() 强转成数字

布尔转数字 true转成1 false转成0

字符串转数字 不能强转

3、引用数据类型

java: Object obj = new Object();

js: var obj = new Object();

var num = new Number();

4、运算符

(1)赋值运算符 var x = 5; (2)算数运算符 + - * / % +: 遇到字符串变成连接 -:先把字符串转成数字然后进行运算 *: 先把字符串转成数字然后进行运算 /: 先把字符串转成数字然后进行运算 (3)逻辑运算符 && || (4)比较运算符 < > >= <= != == ===:全等:类型与值都要相等 (5)三元运算符 3<2?"大于":"小于" (6)void运算符( ???) <a href="javascript:void(0);">xxxxxx</a> (7)类型运算符 typeof:判断数据类型 返回我的数据类型 instanceof:判断数据类型 是否是某种类型 var obj = new Object(); alert(typeof obj);//object alert(obj instanceof Object);//true

5、逻辑语句

(1)if-else

//条件:

//数字非0 字符串非空====true

if(9){

alert("true--");

}else{

alert("false--");

}

(2)switch

var x = "java";

switch(x){

case "css":

alert("css");

break;

case "js":

alert("js");

break;

case "java":

alert("java");

break;

default:

alert("def");

}

(3)for

for(var i = 0;i<5;i++){

alert(i);

}

(4)for in

var arr = [1,3,5,7,"js"];

for(index in arr){//index代表角标

//alert(index);

alert(arr[index]);

}

三、js内建对象

(1)Number

创建方式:

var myNum=new Number(value);

var myNum=Number(value);

属性和方法:

toString():转成字符串

valueOf():返回一个 Number 对象的基本数字值

(2)Boolean

创建方式:

var bool = new Boolean(value);

var bool = Boolean(value);

属性和方法:

toString():转成字符串

valueOf():返回一个 Boolean 对象的基本值(boolean)

(3)String

创建方式:

var str = new String(s);

var str = String(s);

属性和方法:

length:字符串的长度

charAt():返回索引字符

charCodeAt:返回索引字符unicode

indexOf():返回字符的索引

lastIndexOf();逆向返回字符的索引

split();将字符串按照特殊字符切割成数组

substr():从起始索引号提取字符串中指定数目的字符

substring():提取字符串中两个指定的索引号之间的字符

toUpperCase();转大写

示例:

(4)Array

创建方式:

var arr = new Array();//空数组

var arr = new Array(size);//创建一个指定长度的数据

var arr = new Array(element0, element1, ..., elementn);//创建数组直接实例化元素

var arr = [];//空数组

var arr = [1,2,5,"java"];//创建数组直接实例化元素

属性和方法:

length:数组长度

join():把数组的所有元素放入一个字符串。元素通过指定的分隔符进行分隔一个

pop():删除并返回最后元素

push():向数组的末尾添加一个或更多元素,并返回新的长度

reverse();反转数组

sort();排序

(5)Date

创建方式:

var myDate = new Date();

var myDate = new Date(毫秒值);//代表从1970-1-1到现在的一个毫秒值

属性和方法

getFullYear():年

getMonth():月 0-11

getDate():日 1-31

getDay():星期 0-6

getTime():返回1970年1月1日午夜到指定日期(字符串)的毫秒数

toLocalString();获得本地时间格式的字符串

(6)Math

创建方式:

Math 对象并不像 Date 和 String 那样是对象的类,因此没有构造函数 Math(),像 Math.sin() 这样的函数只是函数,

不是某个对象的方法。您无需创建它,通过把 Math 作为对象使用就可以调用其所有属性和方法。

属性和方法

PI:圆周率

abs():绝对值

ceil():对数进行上舍入

floor():对数进行下舍入

pow(x,y):返回 x 的 y 次幂

random():0-1之间的随机数

round():四舍五入

(7)RegExp

创建方式:

var reg = new RegExp(pattern);

var reg = /^正则规则$/;

规则的写法:

[0-9]

[A-Z]

[a-z]

[A-z]

\d 代表数据

\D 非数字

\w 查找单词字符

\W 查找非单词字符

\s 查找空白字符

\S 查找非空白字符

n+ 出现至少一次

n* 出现0次或多次

n? 出现0次或1次

{5} 出现5

{2,8} 2到8次

方法:

test(str):检索字符串中指定的值。返回 true 或 false

需求:

校验邮箱:

var email = haohao_827@163.com

var reg = /^[A-z]+[A-z0-9_-]*\@[A-z0-9]+\.[A-z]+$/;

reg.test(email);

四、js的函数

1、js函数定义的方式

(1)普通方式

语法:function 函数名(参数列表){函数体}

示例:

function method(){

alert("xxx");

}

method();

(2)匿名函数 (常用)

语法:function(参数列表){函数体}

示例:

var method = function(){

alert("yyy");

};

method();

(3)对象函数 (基本不用)

语法:new Function(参数1,参数2,...,函数体);

注意:参数名称必须使用字符串形式、最后一个默认是函数体且函数体需要字符串形式

示例:

var fn = new Function("a","b","alert(a+b)");

fn(2,5);

2、函数的参数

(1)形参没有var去修饰

(2)形参和实参个数不一定相等

(3)arguments对象 是个数组 会将传递的实参进行封装

function fn(a,b,c){

//var sum = a+b+c;

//alert(sum);

//arguments是个数组 会将传递的实参进行封装

for(var i=0;i<arguments.length;i++){

alert(arguments[i]);

}

}

fn(1,2,4,8);

3、返回值

(1)在定义函数的时候不必表明是否具有返回值

(2)返回值仅仅通过return关键字就可以了 return后的代码不执行

function fn(a,b){

return a+b;

//alert("xxxx");

}

alert(fn(2,3));

五、js的事件

事件

事件源

响应行为

1、js的常用事件

onclick:点击事件

onchange:域内容被改变的事件

需求:实现二级联动

			<select id="city">
	            <option value="bj">北京</option>
				<option value="tj">天津</option>
				<option value="sh">上海</option>
			</select>
			<select id="area">
				<option>海淀</option>
				<option>朝阳</option>
				<option>东城</option>
			</select>
			<script type="text/javascript">
				var select = document.getElementById("city");
				select.onchange = function(){
					var optionVal = select.value;
					switch(optionVal){
						case 'bj':
							var area = document.getElementById("area");
							area.innerHTML = "<option>海淀</option><option>朝阳</option><option>东城</option>";
							break;
						case 'tj':
							var area = document.getElementById("area");
							area.innerHTML = "<option>南开</option><option>西青</option><option>河西</option>";
							break;
						case 'sh':
							var area = document.getElementById("area");
							area.innerHTML = "<option>浦东</option><option>杨浦</option>";
							break;
						default:
							alert("error");
					}
				};				
				
			</script>

onfoucus:获得焦点的事件

onblur:失去焦点的事件

需求: 当输入框获得焦点的时候,提示输入的内容格式

当输入框失去焦点的时候,提示输入有误

			<label for="txt">name</label>
			<input id="txt" type="text" /><span id="action"></span>
			<script type="text/javascript">
				var txt = document.getElementById("txt");
				txt.onfocus = function(){
					//友好提示
					var span = document.getElementById("action");
					span.innerHTML = "用户名格式最小8位";
					span.style.color = "green";
				};
				txt.onblur = function(){
					//错误提示
					var span = document.getElementById("action");
					span.innerHTML = "对不起 格式不正确";
					span.style.color = "red";
				};
			</script>

onmouseover:鼠标悬浮的事件

onmouseout:鼠标离开的事件

需求:div元素 鼠标移入变为绿色 移出恢复原色

#d1{background-color: red;width:200px;height: 200px;}

<div id="d1"></div>

<script type="text/javascript">

var div = document.getElementById("d1");

div.onmouseover = function(){

this.style.backgroundColor = "green";

};

div.onmouseout = function(){

this.style.backgroundColor = "red";

};

</script>

onload:加载完毕的事件

等到页面加载完毕在执行onload事件所指向的函数

<span id="span"></span>

<script type="text/javascript">

window.onload = function(){

var span = document.getElementById("span");

alert(span);

span.innerHTML = "hello js";

};

</script>

2、事件的绑定方式

(1)将事件和响应行为都内嵌到html标签中

<input type="button" value="button" οnclick="alert('xxx')"/>

(2)将事件内嵌到html中而响应行为用函数进行封装

<input type="button" value="button" οnclick="fn()" />

<script type="text/javascript">

function fn(){

alert("yyy");

}

</script>

(3)将事件和响应行为 与html标签完全分离

<input id="btn" type="button" value="button"/>

<script type="text/javascript">

var btn = document.getElementById("btn");

btn.onclick = function(){

alert("zzz");

};

</script>

****this关键字

this经过事件的函数进行传递的是html标签对象 ,可以获取标签里任意的属性

<input id="btn" name="mybtn" type="button" value="button123" οnclick="fn(this)"/>

<script type="text/javascript">

function fn(obj){

alert(obj.name);

}

</script>

3、阻止事件的默认行为

IE:window.event.returnValue = false;

W3c: 传递过来的事件对象.preventDefault();

//ie:window.event.returnValue = false;

//W3c:传递过来的事件对象.preventDefault();

//W3c标准

if(e&&e.preventDefault){

alert("w3c");

e.preventDefault();

//IE标签

}else{

alert("ie");

window.event.returnValue = false;

}

//通过事件返回false也可以阻止事件的默认行为

<a href="demo11.html" οnclick="return false">点击我吧</a>

4、阻止事件的传播

IE:window.event.cancelBubble = true;

W3c: 传递过来的事件对象.stopPropagation();

if(e&&e.stopPropagation){

alert("w3c");

e.stopPropagation();

//IE标签

}else{

alert("ie");

window.event.cancelBubble = true;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值