最后
中年危机是真实存在的,即便有技术傍身,还是难免对自己的生存能力产生质疑和焦虑,这些年职业发展,一直在寻求消除焦虑的依靠。
-
技术要深入到什么程度?
-
做久了技术总要转型管理?
-
我能做什么,我想做什么?
-
一技之长,就是深耕你的专业技能,你的专业技术。(重点)
-
独立做事,当你的一技之长达到一定深度的时候,需要开始思考如何独立做事。(创业)
-
拥有事业,选择一份使命,带领团队实现它。(创业)
一技之长分五个层次
-
栈内技术 - 是指你的前端专业领域技术
-
栈外技术 - 是指栈内技术的上下游,领域外的相关专业知识
-
工程经验 - 是建设专业技术体系的“解决方案”
-
带人做事 - 是对团队协作能力的要求
-
业界发声 - 工作经验总结对外分享,与他人交流
永远不要放弃一技之长,它值得你长期
信仰持有
。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
主要内容包括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的使用、函数的封装、对象等内容;
提示:以下是本篇文章正文内容,下面案例可供参考
=============================================================================
1、只有函数才有arguments对象,每个函数都内置有arguments对象;
2、arguments里面储存了所有传递过来的实参;
3、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() 等等
注意:以下输入的数组元素对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,封装到函数内部,每次使用时,直接传入形参调用函数即可。
实现将某一数组元素进行翻转;
代码如下(示例):
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]));
将输入的数组元素内部元素进行从小到大或从大到小排列;
代码如下(示例):
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]));
闰年:能被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();
==========================================================================
代码如下(示例):
// 1. 利用函数关键字自定义函数(命名函数)
function fn() {
}
声明一个变量将匿名函数传入变量中;函数表达式声明方式跟声明变量差不多,只不过变量里面存的是值 而 函数表达式里面存的是函数;
代码如下(示例):
// 2. 函数表达式(匿名函数)
// var 变量名 = function() {};
var fun = function(aru) {
console.log(‘我是函数表达式’);
console.log(aru);
}
fun(‘老师’);
// (1) fun是变量名 不是函数名
// (2) 函数表达式声明方式跟声明变量差不多,只不过变量里面存的是值 而 函数表达式里面存的是函数
// (3) 函数表达式也可以进行传递参数
=====================================================================================
作用域限制代码中的变量起作用的范围,这样能保证代码的可靠性,相同的变量名在不同的作用域下不会出现命名冲突;
注:ES6才有块级作用域;
5.1.1 全局作用域
整个script标签和单独的js文件都是全局作用域
全局作用域中不能访问局部作用域里的变量;
5.1.2 局部作用域
函数内部就是局部作用域;
代码如下(示例):
以下函数内部的num1 和外部的num1不会命名冲突;
var num1 = 10;
function fun(aru) {
var num1 = 10; // num1就是局部变量 只能在函数内部使用
num2 = 20;
}
fun();
======================================================================
在全局作用域中的变量;
注:1、在函数内部未声明的变量也是全局变量;
2、外部作用域中不能访问内部作用域的变量;
在局部作用域中的变量叫做局部变量;
注:1、函数的形参也叫做局部变量;
2、内部函数可以访问外部函数的变量
===============================================================================
作用域链:内部函数在访问外部函数的变量时,采用的是就近原则,选取离内部函数最近的那个变量的值;
代码如下(示例):
var num = 10;
function fn() { // 外部函数
var num = 20;
function fun() { // 内部函数
console.log(num);
}
fun();
}
fn();
==============================================================================
js引擎在执行js代码有两步:1、预解析 2、执行js代码;
8.1.1 变量提升
变量提升是将所有的变量声明提升到当前作用域最前面;注:不提升赋值操作!!!
8.1.2 函数提升
函数提升是将所有的函数声明提升到当前作用域最前面;注:不提升函数调用!!!
代码如下(示例):
fun(); // 报错 坑2
var fun = function() {
console.log(22);
}
// 函数表达式 调用必须写在函数表达式的下面
// 相当于执行了以下代码
// var fun;
// fun();
// fun = function() {
// console.log(22);
// }
===================================================================
对象是一系列无序的属性和方法的集合;
9.1.1 对象字面量创建对象
代码如下(示例):
自学几个月前端,为什么感觉什么都没学到??
这种现象在很多的初学者和自学前端的同学中是比较的常见的。
因为自学走的弯路是比较的多的,会踩很多的坑,学习的过程中是比较的迷茫的。
最重要的是,在学习的过程中,不知道每个部分该学哪些知识点,学到什么程度才算好,学了能做什么。
很多自学的朋友往往都是自己去找资料学习的,资料上有的或许就学到了,资料上没有的或许就没有学到。
这就会给人一个错误的信息就是,我把资料上的学完了,估计也-就差不多的了。
但是真的是这样的吗?非也,因为很多人找的资料就是很基础的。学完了也就是掌握一点基础的东西。分享给你一份前端分析路线,你可以参考。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
还有很多的同学在学习的过程中一味的追求学的速度,很快速的刷视频,写了后面忘了前面,最后什么都没有学到,什么都知道,但是什么都不懂,要具体说,也说不出个所以然。
所以学习编程一定要注重实践操作,练习敲代码的时间一定要多余看视频的时间。