2024年最新JavaScript基础跟我学-day5,阿里P8面试官都说太详细了

最后

中年危机是真实存在的,即便有技术傍身,还是难免对自己的生存能力产生质疑和焦虑,这些年职业发展,一直在寻求消除焦虑的依靠。

  • 技术要深入到什么程度?

  • 做久了技术总要转型管理?

  • 我能做什么,我想做什么?

  • 一技之长,就是深耕你的专业技能,你的专业技术。(重点)

  • 独立做事,当你的一技之长达到一定深度的时候,需要开始思考如何独立做事。(创业)

  • 拥有事业,选择一份使命,带领团队实现它。(创业)

一技之长分五个层次

  • 栈内技术 - 是指你的前端专业领域技术

  • 栈外技术 - 是指栈内技术的上下游,领域外的相关专业知识

  • 工程经验 - 是建设专业技术体系的“解决方案”

  • 带人做事 - 是对团队协作能力的要求

  • 业界发声 - 工作经验总结对外分享,与他人交流

永远不要放弃一技之长,它值得你长期信仰持有

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

主要内容包括html,css,html5,css3,JavaScript,正则表达式,函数,BOM,DOM,jQuery,AJAX,vue 等等。

  • 6.2 局部变量

  • 七、JavaScript作用域链

    • 作用域链:内部函数在访问外部函数的变量时,采用的是就近原则,选取离内部函数最近的那个变量的值;
  • 八、JavaScript预解析

    • 8.1 预解析的步骤
    • 8.1.1 变量提升
  • 8.1.2 函数提升

  • 九、对象

    • 9.1创建对象的方式
    • 9.1.1 对象字面量创建对象
  • 9.1.2 new关键字创建对象

  • 9.1.3 构造函数创建对象

  • 9.2 如何使用对象

    • 9.2.1 调用对象属性
  • 9.2.2 调用对象内部的方法

  • 9.3 对象内部属性、方法分别和变量、函数的区别

    • 9.3.1 属性和变量的区别
  • 9.3.2 方法和函数的区别

  • 9.4 对象new关键字的执行过程

  • 9.5 遍历对象


前言

=================================================================

本文主要讲解arguments的使用、函数的封装、对象等内容;


提示:以下是本篇文章正文内容,下面案例可供参考

一、arguments的使用

=============================================================================

1、只有函数才有arguments对象,每个函数都内置有arguments对象;

2、arguments里面储存了所有传递过来的实参;

3、arguments被称为伪数组;

1.arguments和数组的区别


1、其具有数组元素的length属性;

2、其和数组一样按照索引的方式进行储存;

3、其不具备真正数组的一些方法;如pop(),push()等等;

// arguments 的使用 只有函数才有 arguments对象 而且是每个函数都内置好了这个arguments

// 作用: 里面存储了所有传递过来的实参

function fn() {

// console.log(arguments); // 里面存储了所有传递过来的实参 arguments = [1,2,3]

// console.log(arguments.length);

// console.log(arguments[2]);

// 我们可以按照数组的方式遍历arguments

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

console.log(arguments[i]);

}

}

fn(1, 2, 3);

fn(1, 2, 3, 4, 5);

// 伪数组 并不是真正意义上的数组

// 1. 具有数组的 length 属性

// 2. 按照索引的方式进行存储的

// 3. 它没有真正数组的一些方法 pop() push() 等等

2.利用arguments实现数组元素的反转;


注意:以下输入的数组元素对arguments来说,接收的元素数量为1,要想对接收的数组元素内部数据进行操作,需要arguments[0],先获取数组元素,再对数组元素进行下一步操作;

function reverse () {

var newArr = [];

for(var i = arguments[0].length - 1 ; i >= 0; i–){

newArr[newArr.length] = arguments[0][i];

}

return newArr;

}

console.log(reverse([1,2,3,4,5]));

二、函数的封装

======================================================================

为了方便使用代码实现的功能,可以将实现某个功能的代码片段,利用return,封装到函数内部,每次使用时,直接传入形参调用函数即可。

2.1 封装数组翻转


实现将某一数组元素进行翻转;

代码如下(示例):

function reverse (arr){

var newArr = [];

for(var i = arr.length - 1; i >= 0; i–){

newArr[newArr.length] = arr[i];

}

return newArr;

}

console.log(reverse([1,2,3,4,5]));

2.2 封装冒泡排序


将输入的数组元素内部元素进行从小到大或从大到小排列;

代码如下(示例):

function sort(arr){

for(var i = 0 ;i < arr.length - 1; i++){

for(var j = 0 ;j < arr.length - i -1; j++){

if(arr[j] > arr[j+1]){

var temp = 0;

temp = arr[j];

arr[j] = arr[j+1];

arr[j+1] = temp;

}

}

}

return arr;

}

console.log(sort([1,4,6,2,8,0]));

2.3 封装判断闰年程序


闰年:能被4整除且不能被100整除,或能被400整除

代码如下(示例):

//闰年:能被4整除且不能被100整除,或能被400整除

function isRunYear(year){

return year % 4 == 0 && year % 100 != 0 || year % 400 == 0;

}

console.log(isRunYear(2000));

三、函数调用另外一个函数

===========================================================================

在一个函数内部可以调用另外一个定义的函数;

代码如下(示例):

//在函数内部是可以调用另一个函数

function fn1() {

console.log(11);

fn2(); // 在fn1 函数里面调用了 fn2 函数

}

fn1();

四、函数声明的两种方式

==========================================================================

4.1 function关键字声明函数


代码如下(示例):

// 1. 利用函数关键字自定义函数(命名函数)

function fn() {

}

4.2 函数表达式


声明一个变量将匿名函数传入变量中;函数表达式声明方式跟声明变量差不多,只不过变量里面存的是值 而 函数表达式里面存的是函数;

代码如下(示例):

// 2. 函数表达式(匿名函数)

// var 变量名 = function() {};

var fun = function(aru) {

console.log(‘我是函数表达式’);

console.log(aru);

}

fun(‘老师’);

// (1) fun是变量名 不是函数名

// (2) 函数表达式声明方式跟声明变量差不多,只不过变量里面存的是值 而 函数表达式里面存的是函数

// (3) 函数表达式也可以进行传递参数

五、JavaScript作用域(ES6之前)

=====================================================================================

5.1 作用域的作用


作用域限制代码中的变量起作用的范围,这样能保证代码的可靠性,相同的变量名在不同的作用域下不会出现命名冲突;

注:ES6才有块级作用域;

5.1 作用域种类


5.1.1 全局作用域

整个script标签和单独的js文件都是全局作用域

全局作用域中不能访问局部作用域里的变量;

5.1.2 局部作用域

函数内部就是局部作用域;

代码如下(示例):

以下函数内部的num1 和外部的num1不会命名冲突;

var num1 = 10;

function fun(aru) {

var num1 = 10; // num1就是局部变量 只能在函数内部使用

num2 = 20;

}

fun();

六、变量的类型

======================================================================

6.1 全局变量


在全局作用域中的变量;

注:1、在函数内部未声明的变量也是全局变量;

2、外部作用域中不能访问内部作用域的变量;

6.2 局部变量


在局部作用域中的变量叫做局部变量;

注:1、函数的形参也叫做局部变量;

2、内部函数可以访问外部函数的变量

七、JavaScript作用域链

===============================================================================

作用域链:内部函数在访问外部函数的变量时,采用的是就近原则,选取离内部函数最近的那个变量的值;


代码如下(示例):

var num = 10;

function fn() { // 外部函数

var num = 20;

function fun() { // 内部函数

console.log(num);

}

fun();

}

fn();

八、JavaScript预解析

==============================================================================

js引擎在执行js代码有两步:1、预解析 2、执行js代码;

8.1 预解析的步骤


8.1.1 变量提升

变量提升是将所有的变量声明提升到当前作用域最前面;注:不提升赋值操作!!!

8.1.2 函数提升

函数提升是将所有的函数声明提升到当前作用域最前面;注:不提升函数调用!!!

代码如下(示例):

fun(); // 报错 坑2

var fun = function() {

console.log(22);

}

// 函数表达式 调用必须写在函数表达式的下面

// 相当于执行了以下代码

// var fun;

// fun();

// fun = function() {

// console.log(22);

// }

九、对象

===================================================================

对象是一系列无序的属性和方法的集合;

9.1创建对象的方式


9.1.1 对象字面量创建对象

代码如下(示例):

自学几个月前端,为什么感觉什么都没学到??


这种现象在很多的初学者和自学前端的同学中是比较的常见的。

因为自学走的弯路是比较的多的,会踩很多的坑,学习的过程中是比较的迷茫的。

最重要的是,在学习的过程中,不知道每个部分该学哪些知识点,学到什么程度才算好,学了能做什么。

很多自学的朋友往往都是自己去找资料学习的,资料上有的或许就学到了,资料上没有的或许就没有学到。

这就会给人一个错误的信息就是,我把资料上的学完了,估计也-就差不多的了。

但是真的是这样的吗?非也,因为很多人找的资料就是很基础的。学完了也就是掌握一点基础的东西。分享给你一份前端分析路线,你可以参考。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

还有很多的同学在学习的过程中一味的追求学的速度,很快速的刷视频,写了后面忘了前面,最后什么都没有学到,什么都知道,但是什么都不懂,要具体说,也说不出个所以然。

所以学习编程一定要注重实践操作,练习敲代码的时间一定要多余看视频的时间。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值