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

简介: 笔记

1. JS函数


1.1 函数(Function)是什么?


函数(方法)是由事件驱动的或者当它被调用时执行的可重复使用的代码块 —— 官方说明

向来觉得官方的文档是有些生硬的,举个例子:

函数可以看做是功能(以一辆汽车为例,如下图),这些都可以看做成是方法


刹车

油门

鸣笛

档位30.png

  • 这些功能任何一个里面都有很多个零件的配合,共同完成某一个任务,我们只需要去调用(踩刹车,踩油门,按喇叭,挂挡),功能就会执行
  • 函数也是一样的,它内部封装了一些操作,只有我们去调用的时候才会执行

1.2 一个最简单的函数及触发方法

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>我的第一个方法</title>
    </head>
    <body>
        <button onclick="myFunction()">点击触发函数</button>
        <script>
            // 必须有 function关键字,命名通常为驼峰命名,首字母小写
            function myFunction(){
                alert("这是我的函数");
            }
        </script>
    </body>
</html>

1.3 带参数的函数(形参与实参)

  • 形参 : 函数中定义的变量(此时是没有值的,只是一个代称)
  • 实参 : 在运行时的函数调用时传入的参数(实际的值)
  • js中,方法中即使定义了形参,调用时不传实参也不会报错
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>形参与实参</title>
    </head>
    <body>
        <!-- 这里的5和2是实参 -->
        <button onclick="addNum(5, 2)">计算5+2的值</button>
        <script>
            // 此处的num1,与num2便是形参
            function addNum(num1, num2){
                alert(num1 + num2)
            }
        </script>
    </body>
</html>

1.4 带有返回值的函数 ———— return

function fn(a, b){
    return a*b;
}
// 调用并给num赋值
let num = fn(3, 5);
console.log(num) // 得到15

1.5 js函数内置对象 ———— arguments(重点,考点)

  • 它是函数一创建就有的
  • 是一个类数组(并不是真正的数组)
  • 方法调用时,可以得到所有传进来的参数
  • 你传多少,我就能拿到多少
function fn(){
    console.log(arguments)
 }
 fn(1, 2, 3, 4);

31.png经典应用 ———— 求一组参数的总和

 function fn(){
    let sum = 0;
    for(let i = 0; i < arguments.length; i++){
        sum += arguments[i];
    }
    // 返回 sum
    return sum
 }
 let allSum = fn(1, 2, 3, 4);
 console.log(allSum)    // 得到10

1.6 函数内的变量


在函数内的定义的变量均为局部变量

函数运行完之后就会销毁(垃圾回收机制),所以外界无法访问

变量应尽量避免重名(局部与全局变量可能会混淆,导致一些意料之外的问题)

function fn() {
    // 此为局部变量
    let a = 5;
    console.log(a)
}
fn();
console.log(a) // 此处报错,无法访问

1.7 匿名函数(难点)

  • 顾名思义指的是没有名字的函数
  • 必须采用下面的语法,否则会报错
(function (){
    //由于没有执行该匿名函数,所以不会执行匿名函数体内的语句。
    console.log("666");
})

匿名自执行函数(类似于JS的单例模式)

(function (){
    console.log("666"); // 此处会打印666
})()


2. JS事件


HTML 事件是发生在 HTML 元素上的事情。

JavaScript 可以触发这些事件。

可以看做是用户的某些操作,或者说业务需要监听的某些操作


2.1 HTML事件


HTML 页面完成加载

HTML input 字段改变时

HTML 按钮被点击

常用事件整理40.png2.2 JavaScript 事件一般用于做什么?

  • 页面加载时触发事件
  • 页面关闭时触发事件
  • 用户点击按钮执行动作
  • 验证用户输入内容的合法性
  • …(用户的一切操作都可以监听

2.3 事件实例

<input id="test" type="button" value="提交"/>
<script>
// 页面加载完触发
window.onload = function(){
    let test = document.getElementById("test");   
    test.addEventListener("click",myfun2);   
    test.addEventListener("click",myfun1);
}
function myfun1(){  
    alert("你好1");
}
function myfun2(){ 
    alert("你好2");
}
</script>

3. JavaScript 对象


在JS里 —— 万物皆为对象

  • 字符串也可以是一个对象
  • 日期是一个对象
  • 数学和正则表达式也是对象
  • 数组是一个对象
  • 函数也可以是对象

3.1 对象定义

  • 对象是变量的容器
  • 写法以键值对的方式(键名:键值)
  • 键值对称之为对象的属性
  • 循环对象一般用 for in
// 对象定义
let person = {
    firstName:"ouyang",
    lastName:"xiu",
    age:18
};
// 循环对象
for(let key in person){
  console.log(key); // 键名
  console.log(person[key])  // 键值
}

3.2 大厂经典面试题分析


let obj = Object.create(null) 与 let obj = {} 有什么区别?


对象字面量创建对象与 Object.create(null)创建对象有什么区别?

一开始是有点懵的,不都是创建对象么,能有啥不同,后面我去试了一下,结果发现还蛮有意思:

let obj = {};
let obj2 = Object.create(null);
console.log(obj);
console.log(obj2)

控制台打印41.png

  • 乍一看,好像没啥区别,都是一个花括号
  • 然而,展开后,确实大有不同


42.png

Object.create(null)创建的对象是非常纯净的,没有任何其它元素

而另一个let创建的对象是带有_proto_的,下面有一些方法与属性,这便是js的原型链继承,它继承了Object的方法和属性。这便是区别。

所以这种区别导致了使用场景不同


如果需要对象的继承属性和方法,那就使用 let obj = {};

如果只需要一个纯净的对象,那就使用 Object.create(null)

比如说,我只需要用对象来保存一些数据,然后进行循环取用,提高循环效率。

这个时候如果对象有原型链,那便会在循环的时候去循环它的各个属性和方法

然而这不是必要的,我们只是要他里面的元素而已,前者会影响循环效率


4. JavaScript prototype(原型对象)


  • 此属性是函数特有的
  • 每个函数都会默认添加一个
  • 用于继承属性和方法
// 创建构造函数
function Person(name, age) {
    this.age = age;
    this.name= name;
    this.fn = function(){
        console.log(this.name)
    }
}
// 创建实例
let person1 = new Person("小明", 18);
let person2 = new Person("小红", 20);
person1.fn(); // 继承父级的方法
person2.fn();
console.log(person1)
console.log(person2)

执行结果

45.png

  • 要添加一个新的属性需要在在构造器函数中添加:
function Person(name, age, sex) {
   // sex为新属性
   this.sex = sex;
   this.age = age;
   this.name= name;
   this.fn = function(){
       console.log(this.name)
   }
}

4.1 prototype 继承


所有的 JavaScript 对象都会从一个 prototype(原型对象)中继承属性和方法:


Date 对象从 Date.prototype 继承

Array 对象从 Array.prototype 继承

Person 对象从 Person.prototype 继承

所有 JavaScript 中的对象都是位于原型链顶端的 Object 的实例


JavaScript 对象有一个指向一个原型对象的链

当试图访问一个对象的属性时,它不仅仅在该对象上搜寻,还会搜寻该对象的原型,以及该对象的原型的原型,依次层层向上搜索,直到找到一个名字匹配的属性或到达原型链的末尾(逐级查找)

Date 对象, Array 对象, 以及 Person 对象从 Object.prototype 继承。


4.2 添加属性和方法

function Person(name, age, sex) {
    // sex为新属性
    this.sex = sex;
    this.age = age;
    this.name= name;
    this.fn = function(){
        console.log(this.name)
    }
}
Person.prototype.newVal = "我是新添加在原型上的值";
let person1 = new Person("小明", 18);
console.log(person1)

一样可以通过继承拿到

1.png


目录
相关文章
|
2月前
|
JavaScript 前端开发 开发者
Nest.js控制器深度解析:路由与请求处理的高级特性
以上就是对 NestJS 控制层高级特性深度解析:从基本概念到异步支持再到更复杂场景下拦截其与管道等功能性组件运用都有所涉及,希望能够帮助开发者更好地理解和运用 NestJS 进行高效开发工作。
321 15
|
2月前
|
JavaScript 前端开发 IDE
TypeScript vs. JavaScript:技术对比与核心差异解析
TypeScript 作为 JavaScript 的超集,通过静态类型系统、编译时错误检测和强大的工具链支持,显著提升代码质量与可维护性,尤其适用于中大型项目和团队协作。相较之下,JavaScript 更灵活,适合快速原型开发。本文从类型系统、错误检测、工具支持等多维度对比两者差异,并提供技术选型建议,助力开发者合理选择。
602 1
|
2月前
|
存储 JavaScript 前端开发
JavaScript 语法全面解析
JavaScript 语法体系丰富且不断更新,从基础的变量声明、数据类型,到复杂的函数、对象、异步语法,每个知识点都需要开发者深入理解并灵活运用。本文梳理的 JS 语法核心内容,可为开发者提供系统的学习框架,后续还需通过大量实践(如编写交互组件、实现业务逻辑)巩固知识,逐步提升 JS 编程能力,应对前端开发中的各类挑战。
|
5月前
|
机器学习/深度学习 JavaScript 前端开发
JS进阶教程:递归函数原理与篇例解析
通过对这些代码示例的学习,我们已经了解了递归的原理以及递归在JS中的应用方法。递归虽然有着理论升华,但弄清它的核心思想并不难。举个随手可见的例子,火影鸣人做的影分身,你看到的都是同一个鸣人,但他们的行为却能在全局产生影响,这不就是递归吗?雾里看花,透过其间你或许已经深入了递归的魅力之中。
247 19
|
6月前
|
JSON 前端开发 Serverless
Mock.js 语法结构全解析
Mock.js 的语法规范介绍,从数据模板定义规范和数据占位符定义规范俩部分介绍, 让你更好的使用 Mock.js 来模拟数据并提高开发效率。
|
8月前
|
资源调度 JavaScript 前端开发
前端开发必备!Node.js 18.x LTS保姆级安装教程(附国内镜像源配置)
本文详细介绍了Node.js的安装与配置流程,涵盖环境准备、版本选择(推荐LTS版v18.x)、安装步骤(路径设置、组件选择)、环境验证(命令测试、镜像加速)及常见问题解决方法。同时推荐开发工具链,如VS Code、Yarn等,并提供常用全局包安装指南,帮助开发者快速搭建高效稳定的JavaScript开发环境。内容基于官方正版软件,确保合规性与安全性。
7432 23
|
8月前
|
设计模式 XML 算法
策略模式(Strategy Pattern)深度解析教程
策略模式属于行为型设计模式,通过定义算法族并将其封装为独立的策略类,使得算法可以动态切换且与使用它的客户端解耦。该模式通过组合替代继承,符合开闭原则(对扩展开放,对修改关闭)。
|
8月前
|
数据采集 前端开发 JavaScript
金融数据分析:解析JavaScript渲染的隐藏表格
本文详解了如何使用Python与Selenium结合代理IP技术,从金融网站(如东方财富网)抓取由JavaScript渲染的隐藏表格数据。内容涵盖环境搭建、代理配置、模拟用户行为、数据解析与分析等关键步骤。通过设置Cookie和User-Agent,突破反爬机制;借助Selenium等待页面渲染,精准定位动态数据。同时,提供了常见错误解决方案及延伸练习,帮助读者掌握金融数据采集的核心技能,为投资决策提供支持。注意规避动态加载、代理验证及元素定位等潜在陷阱,确保数据抓取高效稳定。
263 17
|
8月前
|
JavaScript 算法 前端开发
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
8月前
|
存储 JavaScript 前端开发
全网最全情景,深入浅出解析JavaScript数组去重:数值与引用类型的全面攻略
如果是基础类型数组,优先选择 Set。 对于引用类型数组,根据需求选择 Map 或 JSON.stringify()。 其余情况根据实际需求进行混合调用,就能更好的实现数组去重。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

推荐镜像

更多
  • DNS
  • 下一篇
    oss云网关配置