Mobx状态管理(1),2024年最新面试web前端开发十大问题及答案

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
img

正文

@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属性的表达式

使用Mobx创建出来仓库的方法和值


  1. 首先我们需要得到组件前加@observer

  2. 然后在组件中传递一个独特的Store属性,使其值等于一个new出来的Mobx仓库

  3. 使用其中的方法和变量时,用过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 (备注前端)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
dnimg.cn/img_convert/7ae8b7d1bb444279fc6aa23d42173794.png)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-YKh69LZG-1713150853279)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 28
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值