JavaScript入门保姆级教程 ——— 重难点详细解析(万字长文,建议收藏)

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: JavaScript入门保姆级教程 ——— 重难点详细解析(万字长文,建议收藏)

基本语法、事件

一、JavaScript简介

JavaScript(原名:ECMAScript):网景 (Netscape)公司开发,基于浏览器的,解释型的脚本语言(写在Html中)


作用

1. 表单验证
2. 页面特性
3. 操作页面元素

注意:JS是弱类型语言;严格区分大小写,且存在浏览器差异


一门客户端脚本语言

* 运行在客户端浏览器中的。每一个浏览器都有JavaScript的解析引擎
* 脚本语言:不需要编译,直接就可以被浏览器解析执行了

功能:

 # jsp: java服务页面 实现页面的动态效果 动的是数据 ${requestScope.name}
 # js:              实现页面的动态效果 动的是页面结构(标签)
 可以来增强用户和html页面的交互过程,可以来控制html元素,
    让页面有一些动态的效果,增强用户的体验。操作Html的页面结构

JavaScript发展史:

1. 1992年,Nombase公司,开发出第一门客户端脚本语言,专门用于表单的校验。命名为 : C--  ,
后来更名为:ScriptEase
2. 1995年,Netscape(网景)公司,开发了一门客户端脚本语言:LiveScript。
后来,请来SUN公司的专家,修改LiveScript,命名为JavaScript
3. 1996年,微软抄袭JavaScript开发出JScript语言
4. 1997年,ECMA(欧洲计算机制造商协会),制定出客户端脚本语言的标准:ECMAScript,
就是统一了所有客户端脚本语言的编码方式。
* JavaScript = ECMAScript + JavaScript自己特有的东西(BOM+DOM)

注意事项:

# js和java没有关系 独立的编程语言
# js是一种解释型编程语言
     编译型:运行效率高,不能跨平台  源码--》字节码 运行的字节码 C C++
     解释型: 逐行解释运行,运行效率低,运行的是源代码,能跨平台 js
     先编译再解释: 运行效率较高 可跨平台 java
# js的解释器---浏览器
  WebKit 内核系列:chrome、360..【标准w3c组织】
  IE内核系列:IE浏览器(IE 6.0版本以前)
  js浏览器差异:解析过程中也存在浏览器差异的
# js代码核心功能是操作页面结构,不能独立运行,依托与HTML运行

二、JavaScript使用

1. 基本语法:
    1. 与html结合方式
      1. 内部JS:
        * 定义<script>,标签体内容就是js代码
      2. 外部JS:
        * 定义<script>,通过src属性引入外部的js文件
      * 注意:
        1. <script>可以定义在html页面的任何地方。但是定义的位置会影响执行顺序。
        2. <script>可以定义多个。
    2. 注释
      1. 单行注释://注释内容
      2. 多行注释:/*注释内容*/

1、引入js方式

在html代码中通过<script>标签嵌套js代码
<script type="text/javascript">
//js语句
</script>
注意;在开发过程中通常会将这段代码放在<head></head>标签中
<head>
<script type="text/javascript">
//js语句
</script>
</head>

2、js中输出

1. 向浏览器窗口中输出HelloWord
  <script type="text/javascript">
    document.write("<h1>HelloWord</h1>");
  </script>
2.一警告框的形式打印输出结果
 <script type="text/javascript">
  window.alert("HelloWord");
  </script>
3.向浏览器控制台输出结果
<script type="text/javascript">
    console.info("HelloWord");
</script>

·案例·:


 <script type="text/javascript">
        <!--书写js代码-->
        //在HTML中页面输出
        document.write("helloWord")
        //浏览器弹框输出 参数:输出的内容,阻断后续程序运行
        alert("helloWord");
        //浏览器控制台输出 快捷键:F12
        /**
         * console.log()、console.info()、console.debug()的作用都是在浏览器控制台打印信息的。
         使用最多的是console.log()。
         console.info()和console.debug()本质上与console.log()没有区别。
         是console.log()的另一个名字而以,可以理解为它们三个其实就是同一个,只不过名字不一样。
         其中,console.info()打印出的信息,在控制显示的时候信息前面会出现一个小图标,
         而且谷歌浏览器和opera不支持console.debug()。
         */
        console.log("helloWord");
        console.info("Hello World!")
    </script>

3、变量

1.js是一种弱类型类型语言
java--是一种强类型语言(变量的类型和值的类型一致)
int a=3; String str="whj";
js--是一种弱类型的语言(只有值类型,没有变量类型)
var a=3; a="whj"
*强类型:在开辟变量存储空间时,定义了空间将来存储的数据的数据类型。
        只能存储固定类型的数据
* 弱类型:在开辟变量存储空间时,不定义空间将来的存储数据类型,
         可以存放任意类型的数据。
2.js的变量定义
变量:一小块存储数据的内存空间
变量可可以多次重名声明定义赋值,值以最后一次有值的赋值为准
var a=4; a=false; a="hehe";
typeof运算符:获取变量的类型。
* 注:null运算后得到的是object

4、数据类型


1.基本数据类型
数字类型--不分小数和整数
字符串类型--不分字符和字符串,用单引号或者双引号声明定义 “hjehe”
布尔类型--true|false 非0|0(false) 非空|null(false)
*1. number:数字。 整数/小数/NaN(not a number 一个不是数字的数字类型)
*2. string:字符串。不区分字符和字符串,不区分单双引号 字符串  "abc" "a" 'abc'
*3. boolean: true和false
*4. null:一个对象为空的占位符
*5. undefined:未定义。如果一个变量没有给初始化值,则会被默认赋值为undefined
3.引用、复合型数据类型
数组 日期 对象 函数类型
4.JS特殊语法:
      1. 语句以;结尾,如果一行只有一条语句则 ;可以省略 (不建议)
      2. 变量的定义使用var关键字,也可以不使用
            * 用: 定义的变量是局部变量
            * 不用:定义的变量是全局变量(不建议)
5、特殊类型:
   NAN not a number 进行了不正常的数字运算  “whj/2”=NAN
   undefined 变量声明后未赋值直接使用 var a; alert(a);
   null 变量手工赋值为null,函数返回值为null
6、关键字 tepyof 查看当前变量的实际数据类型 使用方式
    var a="10";
    var b=10;
    alert(a=b);//true
    alert(typeof a);//string
    alert(typeof b)//number
    alert(typeof a= typeof b);//true

5、运算符

1.数学运算符:+ - / % *
注意:只有能计算出结果 ,js就会自动类型转换切换运算出结果
2、判断相等性 :== ===
==:比较两种是否相等
var a=3; var b="3" alter(a==b)-->true
===:比较值和类型是否相等
var a=3; var b="3" alter(a===b)-->false
例:
<script type="text/javascript">
   a=3; b="3"; window.alert(a===b);
</script>
3.typeof 判断变量的类型
4.三元运算符
        ? : 表达式
        var a = 3;
            var b = 4;
            var c = a > b ? 1:0;
        * 语法:
          * 表达式? 值1:值2;
          * 判断表达式的值,如果是true则取值1,如果是false则取值2;

6、JavaScript流程控制

1、判断语句 ---与java一样
if(){}
if()else{}
switch(a) case  java中a的值:byte,short,int,char,String(1.7以后)  js:没要求
2、循环控制:
for(var i=0;i++){}
while(){}
do()while()


image.png

7、练习:99乘法表

<head>
    <meta charset="UTF-8">
    <title>Title</title>
  <script>
<!--    99乘法表-->
    document.write("<table align='center'>");
//控制行数
for (var i = 1; i <=9 ; i++) {
  document.write("<tr>");
  for (var j = 1; j <=i ; j++) {
    document.write("<td>");
    document.write(i+"*"+j+"="+(i*j)+"&nbsp;&nbsp;&nbsp;");
    document.write("</td>");
  }
  //换行输出
  document.write("</tr>");
}
document.write("</table>");
  </script>
</head>

三、自定义函数【重点】

概念:特点功能的代码块,可以反复调用


在js例函数被定义为一种数据类型,一个函数也可以称为“一个函数类型的值”,保存之这个值的变量就是函数名


定义函数


1.使用关键字function定义函数
function 函数名(参数名,....){函数体}
function add(a,b){return a+b;}
调用:函数名+参数表 :
    add(10,20);
2.隐式声明(匿名)定义
语法:var函数名=function(函数名){函数体}
  用function定义一个函数,将其看做是一个值,将这个值赋值给变量。
  例如:var add=function add(a,b){return a+b;}
  使用:变量名(实参)
  add(5,2);
3.函数类型值可以在变量间赋值
  var f1=function(){return "hehe"}
  var f2=f1;-->将f1这个函数赋值给f2,f2也是一个函数
  var f3=f1():-->将f1这个函数的结果赋值给f3,f3就是字符串“hehe”

4、函数可以作为函数的参数【常用】


image.png


实现方法二:
test(function (i,j)){
  return i+j;
}

案例:将java中的排序放到前端使用


image.png

5、函数可以不按照规定传递参数


  function add(i+j){
  return i+j;
  }
  var result1=add(1);  //1+undefined=NaN
  var result1=add(1,2);//3
  var result1=add(1,2,3,4);//3(只取前两位)
  * 注意:js中的函数可以不按照指定参数去传参,可能会出问题

1、内置数组对象Arguments[重点]

注意事项:


js里没有“方法重载”,调用函数时可以传入多余or少于形参数量的实参。
js将所有的实参默认保存在一个叫做arguments的数组里。
注:arguments(争吵)只能在函数内部使用
function add(i,j){
  if(typeof i=="number"&&typeof="number"){
       if(arguments.length==2){
           return i+j;
        }else{
           alert("类型有误,请重新输入");
        }
        }else{
             alert("参数个数有错,请重新输入");
        }
  }
  *arguments作用:增强函数的健壮性

2、内置函数

1.parseInt函数:把str转化成number整数
document.write(parseInt("123")+"<br/>");//123
document.write(parseInt("1.23")+"<br/>")//1
document.write(parseInt("1a23")+"<br/>");//1
document.write(parseInt("a123")+"<hr/>");//NaN
2.parseFloat函数:把str转化成number小数
document.write(parseFloat("3.14")+"<br/>")//3.14
document.write(parseFloat("a123")+"<br/>");//NaN(not 啊number)
document.write(parseFloat("1a.23")+"<br/>")//1

四、对象

1、对象类型

# js语言是一门类(类似)的面向对象的编程语言,js没有类的概念
#1、在js里只有对象,没有类,任意两个对象都不一样
# 2.定义一个对象
  语法:var obj={属性名:属性值,属性名:属性值,.......};
#3.访问对象的属性
(1)访问一个属性:对象名  或者 对象名{"属性名"}
(2)遍历所有属性: 对象名.属性名 或者 对象名["属性名"]
     循环每一次执行,都会从对象中获取一个属性值,赋值给指定的变量名。
    属性特点:
         1. 方法定义是,形参的类型不用写,返回值类型也不写。
         2. 方法是一个对象,如果定义名称相同的方法,会覆盖
         3. 在JS中,方法的调用只与方法的名称有关,和参数列表无关
         4. 在方法声明中有一个隐藏的内置对象(数组),arguments,封装所有的实际

2、自定义对象:自己定义的对象

(1)new Object();方式创建对象 【了解】

 

  <script type="text/javascript">
        //创建一个学生对象
        var student = new Object();
        //属性+方法 属性的定义 对象名.属性名
        student.id = 1;
        student.name = '王恒杰';
        student.age = 21;
        //获取属性值
        alert("id是:" + student.id);
        alert("名字是:" + student.name);
        alert("年龄是:" + student.age);
        student.getId=function(){
            return this.id;
        }
       student.setId=function(id){
            this.id=id
        }
       student.getName=function(){
            return this.name;
        }
        student.setName=function(name){
            this.name=name;
        }
        student.getAge=function(){
            return this.age;
        }
        student.setAge=function(age){
            this.age=age;
        }
        alert(student.getName());
        student.setName("王恒杰whj");
        alert(student.getName());
    </script>

(2)同构系统与异构系统

# 异构系统通过XML,JSON,字符串进行多语言的通讯,因为这些都是规定好的,各个语言中使用都是一样的。例如JavaScript和Java通过Json进行数据交换,JavaScript利用eval()函数,而Java有jackson,json-lib等类库来进行帮忙解析。
# 不使用xml的原因:JSON 相对于XML要轻量,XML就比较笨重了,所以现在很多数据传输都在逐渐转为使用JSON来作为传输数据的方式。(2)同构系统与异构系统

同构系统


image.png

异构系统


image.png

(3)json形式对象创建

是一种数据交换格式,本质就是一个特殊形式的字符串 —— json串

特殊形式:{key:value , key1 : value1…}


  <script type="text/javascript">
        //创json建一个对象
        var student = {
            id: 1, name: 'whj', age: 18, getAge: function () {
                return this.age;
            }, setAge: function (age) {
                this.age = age;
            },
            //有play方法(play方法返回一个字符串值)
            play:function(){return "hehe"}
        }
        //访问属性
        alert(student.id);
        alert(student.name);
        alert(student.age);
        //访问方法(模拟)
        alert(student.getAge());
        student.setAge(58);
        alert(student.getAge());
        alert(student.play)
    </script>
 *异常:Assiguments patterns must be on the left side of assignment
       分配模式必须在分配模式的左侧,写:不要写=
 *typeof运算符:获取变量的类型。

3、内置对象:js中准备好的

(1)数组【重点】

# java中数组的特点:定长,元素类型相同  
# js中数组的特点:js里的数组长度不固定,可以任意扩展,数据可以是任意类型。 
<script type="text/javascript">
1.创建数组的两种方式
  //创建数组
  //1.隐式,Array数组对象 new Array();  ing[] arr1=new int[10]
   var arr1=new Array();
  //2.显示,显示初始化数组  var arr2=[元素1,元素2];
    var arr2=[1,2,3,4]
2.操作数组
    var arr1=new Array();
   //操作数组元素 下标
   arr1[0]='whj';
   arr1[1]='yfj';
   //有arr1[2]这种方式
   arr1[3]='whx';
   //获取数组的元素值
  alert(arr1[1]);
3.数组遍历的两种方式  
  //数组遍历
  /**
   * 下标遍历
   * @type {number[]}
   */
  for (var i = 0; i < arr1.length; i++) {
      alert(arr1[i]);
  }
  /**
   * foreach遍历
   * foreach遍历 java: for(当前元素类型 名字,遍历的数组或集合)
   *               js: for(当前元素的下标 in 遍历的数组)
   * @type {number[]}
   */
  for (index in arr1) {
    alert(arr1[index])
  }
</script>

相关属性方法

 var arr2 = [1, 2, 3, 4]
    //压栈(添加数组)
    arr2.push();
    //弹栈(将末尾元素移除)
    arr2.pop();
1.数组对象.sort()--->对数组里的元素按照自然顺序升序排列
2.数组对象.push()--->在数组的末尾插入一个元素
3.数组对象.pop--->删除数组末尾的最后一个元素,且数组长度减1
4.数组对象.join(参数)-->将数组中的元素按照指定的分隔符拼接为字符串
5.delete 数组对象[下标]--->删除数组指定位置元素,且数组长度不变

(2)字符串

  <script type="text/javascript">
    //创建字符串
    var string1 = new String("whj");
    var string2 = "whj";
    alert(string1 + "=====" + string2)
    string2.length;
  </script>

(3)日期

   <script type="text/javascript">
   //日期
   let date = new Date();
   alert(date)
   //获取年
    alert(date.getFullYear());
   // 月 系统是0--11
   alert(date.getMonth()+1);
   // 日
   alert(date.getDate());
   // 时
   alert(date.getHours());
   // 分
   alert(date.getSeconds());
   // 秒
   alert(date.getMinutes());
   //周
   alert(date.getDay());
   //毫秒
   alert(date.getMilliseconds());
  </script>

(4)Math

//随机数 返回0-1之间的随机数
        let number = Math.random();
        alert(number)
             1. 创建:
                * 特点:Math对象不用创建,直接使用。  Math.方法名();
            2. 方法:
                random():返回 0 ~ 1 之间的随机数。 含0不含1
                ceil(x):对数进行上舍入。
                floor(x):对数进行下舍入。
                round(x):把数四舍五入为最接近的整数。
            3. 属性:
                PI
 5. RegExp:正则表达式对象
      1. 正则表达式:定义字符串的组成规则。
        1. 单个字符:[]
          如: [a] [ab] [a-zA-Z0-9_]
          * 特殊符号代表特殊含义的单个字符:
            \d:单个数字字符 [0-9]
            \w:单个单词字符[a-zA-Z0-9_]
        2. 量词符号:
          ?:表示出现0次或1次
          *:表示出现0次或多次
          +:出现1次或多次
          {m,n}:表示 m<= 数量 <= n
            * m如果缺省: {,n}:最多n次
            * n如果缺省:{m,} 最少m次
        3. 开始结束符号
          * ^:开始
          * $:结束
      2. 正则对象:
        1. 创建
          1. var reg = new RegExp("正则表达式");
          2. var reg = /正则表达式/;
        2. 方法  
          1. test(参数):验证指定的字符串是否符合正则定义的规范 

(5)RegExp:正则表达式对象

      1. 正则表达式:定义字符串的组成规则。
        1. 单个字符:[]
          如: [a] [ab] [a-zA-Z0-9_]
          * 特殊符号代表特殊含义的单个字符:
            \d:单个数字字符 [0-9]
            \w:单个单词字符[a-zA-Z0-9_]
        2. 量词符号:
          ?:表示出现0次或1次
          *:表示出现0次或多次
          +:出现1次或多次
          {m,n}:表示 m<= 数量 <= n
            * m如果缺省: {,n}:最多n次
            * n如果缺省:{m,} 最少m次
        3. 开始结束符号
          * ^:开始
          * $:结束
      2. 正则对象:
        1. 创建
          1. var reg = new RegExp("正则表达式");
          2. var reg = /正则表达式/;
        2. 方法  
          1. test(参数):验证指定的字符串是否符合正则定义的规范 

(6)Global


      1. 特点:全局对象,这个Global中封装的方法不需要对象就可以直接调用。  方法名();
      2. 方法:
          encodeURI():url编码
          decodeURI():url解码
          encodeURIComponent():url编码,编码的字符更多
          decodeURIComponent():url解码
          parseInt():将字符串转为数字
              * 逐一判断每一个字符是否是数字,直到不是数字为止,将前边数字部分转为number
          isNaN():判断一个值是否是NaN
              * NaN六亲不认,连自己都不认。NaN参与的==比较全部问false
          eval():讲 JavaScript 字符串,并把它作为脚本代码来执行。 

五、事件[重点]

js代码靠用户触发某些事件,触发js程序运行,当网页里的标签产生浏览器能够捕获的特定事件时,触发js代码运行。


1、事件模型的三要素


image.png

1.事件源:发生事件的事务/对象 通常为HTML页面的**标签** 对象
2.事件的属性:发生事件的性质(动作) 用户的某个操作(如:**单击、双击** 等)
3.监听器:事件发生后的处理 通常在**函数** 中定义处理程序

案例:点击按钮弹窗提示

事件源头:按钮标签

事件属性:单机

事件监听:弹窗提示


<head>
    <script type="text/javascript">
    //函数 事件的监听功能
    function  test1(){
        alert("点击成功")
    }
    </script>
</head>
<body>
<!--准备事件源     绑定事件属性:监听用户的操作:单机事件-->
 <input type="button" value="单机" onclick="test1()">
</body>

事件示例图:



image.png

2、为html标签注册事件的方式

<标签名 属性="" 事件名称="监听器">
如:
<input type="button" onclick="函数名字(参数列表)"/>

3、事件属性

1.鼠标相关
**onclick 单击事件** ***** **
** **ondbclick 双击事件** ***
** **onmouseover 移入鼠标** ***
** **onmouseout 移出鼠标** ***** 
onmousemove 鼠标移动*
onmousedown 鼠标按下
onmouseup 鼠标松开
2.键盘相关
onKeyDown 按键按下*
onKeyUp 按键抬起*
3.body相关事件
onload //页面加载完毕后触发
onunload 窗口离开时触发(刷新,返回,前进,主页。。。。)
onscroll 页面滚动
onresize 缩放页面
4.form表单控件相关事件***
onblur 当前对象失去焦点
onchange 当前元素失去焦点,并且值改变时<input>(监听value属性值的修改)<select>
onfocus 当前对象获得焦点时 <input>
onsubmit 表单提交时(验证表单格式是否正确)
onreset  重置按钮被点击。
onsubmit例:
function xxx(){
if(...){
alert("错误消息");
return false;
}
return true;
}
<form...οnsubmit="return xxx()">

4、注意事项

1.事件冒泡:发生在内部元素的事件默认会向外部元素扩散
   取消事件冒泡===event.cancelBubble=true;
   event--代表监听的事件对象
   event.clientX--事件产生的横坐标
   event.clientY--事件产生的纵坐标
2.通过事件监听可以取消某些标签的默认行为[存在浏览器差异 IE不生效]
超链接标签--》<a href="跳转链接" onclick="return false">
表单标签--》<form action="" metho="get" onsubmit="return false">


相关文章
|
9天前
|
JavaScript 前端开发 Go
CSS 与 JS 对 DOM 解析和渲染的影响
【10月更文挑战第16天】CSS 和 JS 会在一定程度上影响 DOM 解析和渲染,了解它们之间的相互作用以及采取适当的优化措施是非常重要的。通过合理的布局和加载策略,可以提高网页的性能和用户体验,确保页面能够快速、流畅地呈现给用户。在实际开发中,要根据具体情况进行权衡和调整,以达到最佳的效果。
|
14天前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
109 2
|
5天前
|
存储 前端开发 JavaScript
JavaScript垃圾回收机制深度解析
【10月更文挑战第21】JavaScript垃圾回收机制深度解析
86 59
|
2天前
|
监控 前端开发 JavaScript
React 静态网站生成工具 Next.js 入门指南
【10月更文挑战第20天】Next.js 是一个基于 React 的服务器端渲染框架,由 Vercel 开发。本文从基础概念出发,逐步探讨 Next.js 的常见问题、易错点及解决方法,并通过具体代码示例进行说明,帮助开发者快速构建高性能的 Web 应用。
22 10
|
21天前
|
机器学习/深度学习 自然语言处理 JavaScript
信息论、机器学习的核心概念:熵、KL散度、JS散度和Renyi散度的深度解析及应用
在信息论、机器学习和统计学领域中,KL散度(Kullback-Leibler散度)是量化概率分布差异的关键概念。本文深入探讨了KL散度及其相关概念,包括Jensen-Shannon散度和Renyi散度。KL散度用于衡量两个概率分布之间的差异,而Jensen-Shannon散度则提供了一种对称的度量方式。Renyi散度通过可调参数α,提供了更灵活的散度度量。这些概念不仅在理论研究中至关重要,在实际应用中也广泛用于数据压缩、变分自编码器、强化学习等领域。通过分析电子商务中的数据漂移实例,展示了这些散度指标在捕捉数据分布变化方面的独特优势,为企业提供了数据驱动的决策支持。
40 2
信息论、机器学习的核心概念:熵、KL散度、JS散度和Renyi散度的深度解析及应用
|
14天前
|
JavaScript 前端开发 索引
JavaScript ES6及后续版本:新增的常用特性与亮点解析
JavaScript ES6及后续版本:新增的常用特性与亮点解析
14 4
|
17天前
|
存储 JavaScript 前端开发
前端开发:Vue.js入门与实战
【10月更文挑战第9天】前端开发:Vue.js入门与实战
|
19天前
|
JavaScript 前端开发
js教程——函数
js教程——函数
21 4
|
17天前
|
自然语言处理 JavaScript 前端开发
JavaScript高级——ES6基础入门
JavaScript高级——ES6基础入门
17 1
|
13天前
|
JavaScript 前端开发 开发者
原型链深入解析:JavaScript中的核心机制
【10月更文挑战第13天】原型链深入解析:JavaScript中的核心机制
22 0

推荐镜像

更多