发布时间:2023-03-04 09:00
是一门客户端脚本语言
运行在客户端浏览器中的。每一个浏览器都有JavaScript的解析引擎
脚本语言:不需要编译,直接可以被浏览器解析执行
可以来增强用户和html页面的交互过程,可以来控制html元素,让页面有一些动态的效果,增强用户的体验。
JavaScript = ECMAScript + JavaScript自己特有的东西(BOM+DOM)
内部JS:
,标签内容就是js代码外部JS:
定义,通过src属性引入外部的js文件
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
<script>
alert("hello world!!!"); //会阻塞
script>
<script src="a.js">script>
head>
<body>
body>
html>
a.js
alert("我是外部的js");
注意:
可以定义在html页面的任何地方。但是定义的位置会影响执行顺序。
可以定义多个//注释内容
/*注释内容*/
变量:一小块存储数据的内存空间
Java语言是强类型语言,而JavaScript是弱类型语言。
语法
typeof运算符:获取变量的类型
注:null运算后得到的是object
一元运算符:只有一个运算数的运算符
注意:在JS中,如果运算数不是运算符所要求的类型,那么js引擎会自动的将运算数进行类型转换
算数运算符
赋值运算符
比较运算符
===:全等于。在比较之前,先判断类型,如果类型不一样,则直接返回false
逻辑运算符
&& || !
三元运算符
? : 表达式
var a = 3;
var b = 4;
var c = a > b ? 1:0;
语法
创建
var fun = new Function(形式参数列表,方法体); //不建议使用
function 方法名称(形式参数列表){
方法体
}
var 方法名 = function(形式参数列表){
方法体
}
属性
特点
方法定义时,形参的类型不用写,返回值类型也不写。
function fun1(a,b,c){
alert(1);
}
在JS中,方法的调用只与方法的名称有关,和参数列表无关
在方法声明中有一个隐藏的内置对象(数组),arguments,封装所有的实际参数
function add(){
var sum=0;
for (var i = 0; i < arguments.length; i++) {
sum+=arguments[i];
}
return sum;
}
调用
创建
var arr = new Array(元素列表);
var arr = new Array(默认长度);
var arr = [元素列表];
var arr1=new Array(1,2,3);
var arr2=new Array(5);
var arr3=[1,2,4,5];
方法
属性
特点
创建
var date = new Date();
方法
创建
方法
属性
Math.PI
正则表达式:定义字符串的组成规则。
^:开始
$:结束
正则对象
创建
方法
var reg=new RegExp("\\w{6,12}");
var reg2=/^\w{6,12}$/;
// alert(reg);
// alert(reg2);
var username="zhangs";
var flag=reg2.test(username);
alert(flag);
特点:全局对象,这个Global中封装的方法不需要对象就可以直接调用。 方法名();
方法
encodeURI():url编码
decodeURI():url解码
encodeURIComponent():url编码,编码的字符更多
decodeURIComponent():url解码
parseInt():将字符串转为数字
isNaN():判断一个值是否是NaN
eval():将 JavaScript 字符串,并把它作为脚本代码来执行。
<script>
let str="https://www.baidu.com?wd=你好";
let encode=encodeURI(str);
document.write(encode+"
");
document.write(decodeURI(encode)+"
");
let encodeCom=encodeURIComponent(str);
document.write(encodeCom+"
");
document.write(decodeURIComponent(encodeCom)+"
");
var str1="1234asdf";
let number=parseInt(str1);
// alert(isNaN(number));
var n=NaN;
document.write(isNaN(n));
var jsCode="alert(123)";
eval(jsCode);
</script>
如:你好的url编码为 %E4%BD%A0%E5%A5%BD
功能:控制html文档的内容
获取页面标签(元素)对象:Element
操作Element对象:
修改属性值:
明确获取的对象是哪一个?
查看API文档,找其中有哪些属性可以设置
var light=document.getElementById("light");
light.src="img/on.gif";
修改标签体内容:
将浏览器的各个组成部分封装成对象。
与弹出框有关的方法:
与打开关闭有关的方法:
与定时器有关的方法
var openBtn=document.getElementById("openBtn");
var closeBtn=document.getElementById("closeBtn");
var newWindow;
openBtn.onclick=function (){
newWindow=open("https://www.bilibili.com");
}
closeBtn.onclick=function(){
if(newWindow)
newWindow.close();
}
function fun(){
alert("boom!!");
}
// setTimeout(fun,3000);
var id=setInterval(fun,2000);
clearInterval(id);
<body>
<input type="button" id="btn" value="刷新">
<input type="button" id="btn2" value="bilibili">
<script>
var btn=document.getElementById("btn");
btn.onclick=function() {
location.reload();
}
var btn2=document.getElementById("btn2");
btn2.onclick=function(){
location.href="https://www.bilibili.com";
}
script>
body>
window.history
history
length 返回当前窗口历史列表中的 URL 数量。
将标记语言文档的各个组成部分,封装为对象。可以使用这些对象,对标记语言文档进行CRUD的动态操作
W3C DOM 标准被分为 3 个不同的部分:
<body>
<div id="div1">
<div id="div2"> div2div>
div1
div>
<a href="javascript:void(0);" id="del">删除子节点a>
<a href="javascript:void(0);" id="insert">添加子节点a>
<script>
var element_a=document.getElementById("del");
element_a.onclick=function (){
var div1=document.getElementById("div1");
var div2=document.getElementById("div2");
div1.removeChild(div2);
}
var element_a2=document.getElementById("insert");
element_a2.onclick=function(){
var div1=document.getElementById("div1");
var div3=document.createElement("div");
div3.setAttribute("id","div3");
div3.textContent="div3";
// div3.innerHTML="div3";
div1.appendChild(div3);
}
let div2 = document.getElementById("div2");
let div1 = div2.parentNode;
alert(div1);
script>
body>
.标签体的设置和获取:innerHTML
使用html元素对象的属性
控制元素样式
使用元素的style属性来设置
eg
let div1 = document.getElementById("div1");
div1.onclick=function(){
div1.style.border="1px solid red";
div1.style.width="200px";
//font-size
div1.style.fontSize="20px";
}
提前定义好类选择器的样式,通过元素的className属性来设置其class属性值。
.d1{
border: 1px solid red;
width: 100px;
height: 50px;
}
.d2{
border: 1px solid blue;
width: 100px;
height: 100px;
}
let div2 = document.getElementById("div2");
let flag=true;
div2.onclick=function(){
if(flag){
div2.className="d2";
flag=false;
}else{
div2.className="d1";
flag=true;
}
}
某些组件被执行了某些操作后,触发某些代码的执行。
事件:某些操作。如: 单击,双击,键盘按下了,鼠标移动了
事件源:组件。如: 按钮 文本输入框…
监听器:代码。
注册监听:将事件,事件源,监听器结合在一起。 当事件源上发生了某个事件,则触发执行某个监听器代码。
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>常见事件title>
<script>
window.onload=function () {
// document.getElementById("text").οnblur=function(){
// alert("失去焦点");
// }
// document.getElementById("text").οnmοusedοwn=function(event){
// alert(event.button);
// }
/*document.getElementById("text").οnkeydοwn=function(event){
alert(event.keyCode);
}*/
// document.getElementById("text").οnchange=function(event){
// alert("改变了");
// }
// document.getElementById("form").οnsubmit=function () {
// return false;
// }
}
function checkForm() { //检查表单是否符合要求,不符合则返回false阻止表单提交
return false;
}
script>
head>
<body>
<form action="#" id="form" onclick="return checkForm();" > //注意要使用return,不然失效
<input type="text" id="text" name="username">
<input type="submit" value="提交">
form>
body>
html>