先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
正文
@observable:
-
作用:把一个普通成员变量装换为可被观测的成员变量
-
使用方法:@observable 变量名 = 变量值
@action:
-
作用:创建一个可以改变observable创建出来值的方法
-
使用方法:@action 方法名 = 方法体(其中可以使用this来访问同一个类中@observable创建出来的值)
-
不要直接修改store中的数据,最好是使用action装饰的方法来进行修改
@action.bound
-
作用:事先绑定好this
-
案例:
class Store {
@action fun(){
console.log(this)
}
@action.bound fun2(){
console.log(this)
}
}
const obj = new Store()
obj.fun()//输出的是undefined
obj.fun2()//输出的是Store类这个实例对象
action异步操作
-
在启用严格模式后不允许在action中使用异步函数来修改Mobx仓库中的属性
-
解决方法:修改少时推荐使用3,相对复杂时使用1
class store {
@observable count = 0
@action.bound change(){
setTimeout(()=>{
this.count = 100//此时这是不被允许的
//解决方法1:在这里使用其他定义好的action来进行
this.changeCount()
//解决方法2:直接调用action函数,并立即执行
action(()=>{
this.count = 20
})()
//解决方法3:使用runInAction
runInAction(()=>{
this.count = 20
})
},100)
}
@action.bound changeCount(){
this.count = 20
}
}
@observer:
-
作用:在组件中使用Mobx仓库
-
使用方法:在要使用Mobx仓库的组件前添加@observer修饰(前提这个是一个类组件)
autorun:
-
作用:当**被检测的数据(也就是被@observable修饰的变量)**发生改变时就会触发autorun,默认会在一开始执行一次,从而实现视图的更新
-
参数:接收的是一个函数作为参数
-
使用方法:autorun( ( )=>{ 方法体 } )
监事数据发生改变:
computed:
-
计算属性(本质是方法,使用时为属性)
-
作用:将仓库中的数据进行某些操作,例如加减乘除等
-
使用方式:本质是方法,用的时候当成属性使用
class store {
@observable count = 10;
@observable price = 2;
@computed get totalPrice () {
//计算属性的固定写法computed get 方法名,使用的时候只需要写方法名不需要调用
return this.price * this.price
//return是计算得到的结果,依赖于count和price
}
}
@observer
class App export React.Component {
render(){
const { store } = this.props
return (
{ store.totalPrice }
)}
}
- 特性:缓存对应的结果(使用多次计算属性时,实际上只执行了一次这个方法),同时当这里return依赖的值发生改变时会再次进行计算(这里也是只执行一次),并且触发视图更新
autorun:
when:
reaction:
configure(Mobx严格模式):
-
作用:配置Mobx仓库使其只能通过@action修饰的方法改变其中的属性
-
使用方式:
class store {
configure({
enforceAction: “observed”
})
}
runInAction
-
作用:同action类似,是改变Mobx属性的一个工具,这个也是当在内部修改多次属性时只会触发一次computed
-
参数:一个函数,函数体中写修改Mobx属性的表达式
-
首先我们需要得到组件前加@observer
-
然后在组件中传递一个独特的Store属性,使其值等于一个new出来的Mobx仓库
-
使用其中的方法和变量时,用过this.props.独特的Store.方法/变量来使用
什么是装饰器
- 对类进行处理的一个函数,换句话说就是将我们创建出来的类在进行 “修饰”
装饰器 属性(装饰类)
@fun
class MyClass { }
function fun(target) {
target.name = ‘Tom’
}
console.log(MyClass.name) //输出结果为Tom
/*
在这端代码中我们可以看到,fun并没用调用,而是作为一个装饰器来使用
这段代码翻译过来就是
声明一个类MyClass,使用我们自己声明的函数fun来进行装饰
装饰的过程:将MyClass作为参数传递到fun中,为其添加一name的属性
*/
@fun2(10)
class MyClass { }
function fun2(value) {
Vue
-
什么是MVVM?
-
mvvm和mvc区别?它和其它框架(jquery)的区别是什么?哪些场景适合?
-
组件之间的传值?
-
Vue 双向绑定原理
-
描述下 vue 从初始化页面–修改数据–刷新页面 UI 的过程?
-
虚拟 DOM 实现原理
-
Vue 中 key 值的作用?
-
Vue 的生命周期
-
Vue 组件间通信有哪些方式?
-
vue 中怎么重置 data?
-
组件中写 name 选项有什么作用?
-
Vue 的 nextTick 的原理是什么?
-
Vuex 有哪几种属性?
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
dnimg.cn/img_convert/7ae8b7d1bb444279fc6aa23d42173794.png)
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-YKh69LZG-1713150853279)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!