首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JS高级部分

JS高级部分 判断 对象引用类型 undefined与null的探究 区分变量类型和数据类型 数据,变量和内存 js的函数参数传递为值传递 JS引擎如何管理内存 JS对象 什么时候需要使用['属性名'...JS函数对象 call和apply的区别 回调函数 立即执行函数 JS函数中的this指向 JS分号问题 函数的原型对象 显示原型与隐式原型 原型链 原型链的属性问题 instanceOf是如何判断的...的函数参数传递为值传递 当传入的是 基本类型的参数时:就是复制了份内容而已 当传入的是引用类型的参数时: 复制的是引用类型参数的地址 ---- JS引擎如何管理内存 ---- JS对象 ----...浏览器的 JS 执行引擎总是访问栈顶的执行上下文。...模块 JS模块定义方式一: 把上面这段代码写到一个js文件中,在html页面加载这个js文件的时候,js文件中的代码会执行,然后调用返回得到返回值执行即可 JS模块定义方式二:

97031

vue组件高级(上)

/eventBus.js' 调用EventBus的on()方法,声明自定义事件,通过事件回调接收数据 bus.on('自定义事件',(data)=>{}) 3.4.1 具体步骤 1....创建公共的EventBus模块 在项目中创建公共的eventBus模块: //eventBus.js //导入mitt包 import mitt from 'mitt' //创建EventBus的实例对象...在数据接收方自定义事件 在数据接收方,调用 bus.on('事件名称',事件处理函数)方法注册一个自定义事件: //导入eventBus.js模块,得到共享的bus对象 import bus from...在数据发送方触发事件 在数据发送方,调用bus.emit('事件名称',要发送的数据)方法触发自定义事件: //导入eventBus.js模块,得到共享的bus对象 import bus from '..../eventBus.js' export default{ data(){return{count:0}}, methods:{ addCount(){

1.2K10

高级 Angular 组件模式 (6)

组件作者提前了解使用该toggle组件的父组件所需要的状态时,那么它将会正常的运作。但是如果父组件所需要的状态并不在我们的设想之内,我们该怎么办?...目标 将toggle组件的状态直接提供给父组件,同时允许父组件提供相应的渲染视图(view)。 实现 组件可以完美地解决问题。 1....父组件 从toggle组件中传入的状态是通过let关键字在父组件的标签上显示声明的。...toggle>组件的模板作用域中的变量名。...除了上面的解决方法,就是使用正文中所提及的模式了,这种模式将子组件视图的渲染逻辑倒置为子组件仅仅声明模板中所会使用的状态变量,对于这些变量和模板的注入工作,全权赋予父组件,因此会使子组件的复用性和可测试性大大提高

80810

Vue组件开发-高级玩法

在文章《Vue组件开发三板斧:prop、event、slot》中聊了常用的组件开发常用API和一些采坑心得,这里,再说说一些可能不太常用的高级玩法,可参考https://cn.vuejs.org/v2/...组件挂载 方式一:components属性 我们常用的创建组件方式就是文件声明,例如,在一个假设的 headTop.js 或 headTop.vue 文件中定义组件。...}; }, }); Vue.extend是无法挂载组件的,此时需要: 使用$mount 渲染组件或者渲染并挂载组件 使用JS原生方法,挂载组件 // 方式一:仅仅渲染 const component...一般我们写 Vue.js 组件,模板都是写在 内的,但它并不是最终呈现的内容,在 Vue.js 编译阶段,会解析为 Virtual DOM。...( Vue.js 2.2.0 版本后新增的 API) 允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在起上下游关系成立的时间里始终生效。

2.3K30

高级 Vue 组件模式 (1)

写在前头 去年,曾经阅读过一系列关于高级 react 组件模式的文章,今年上半年,又抽空陆陆续续地翻译了一系列关于高级 angular 组件模式的文章,碰巧最近接手了一个公司项目,前端这块的技术栈是 vue...01 实现一个 toggle 组件 这个系列的文章的第一篇,都会从实现一个最简单的 toggle 组件开始。...在 Vue 中,我们通过 data 来声明一个 checked 属性,这个属性所控制的状态代表组件本身的开关状态,这个状态会传递给负责渲染开关变换逻辑的 switch 组件中,关于 switch 组件,...通过在 switch 组件注册原生 click 事件,toggle 组件还会触发一个 toggled 事件,在 App 组件中,我们会监听这个事件,并将其回传的值打印到控制台中。...,checked 代表组件内部的开关状态 通过触发 toggle 事件,将 checked 状态的变化传递给父组件

83510

React高级组件精讲

类似的,高阶组件(简称HOC)接收 React 组件为参数,并且返回一个新的React组件。高阶组件本质也是一个函数,并不是一个组件。...二、使用场景 高阶组件的使用场景主要有以下4中: 操纵 props 通过 ref 访问组件实例 组件状态提升 用其他元素包装组件 1.操纵 props 在被包装组件接收 props 前, 高阶组件可以先拦截到...2.通过 ref 访问组件实例 高阶组件 ref 获取被包装组件实例的引用,然后高阶组件就具备了直接操作被包装组件的属性或方法的能力。...3.组件状态提升 高阶组件可以通过将被包装组件的状态及相应的状态处理方法提升到高阶组件自身内部实现被包装组件的无状态化。...一个典型的场景是,利用高阶组件将原本受控组件需要自己维护的状态统一提升到高阶组件中。

98720

高级 Vue 组件模式 (3)

03 使用 mixin 来增强 Vue 组件 目标 之前一篇文章中,我们虽然将 toggle 组件划分为了 toggle-button、toggle-on 和 toggle-off 三个子组件,且一切运行良好...,但是这里面其实是存在一些问题的: toggle 组件的内部状态和方法只能和这三个子组件共享,我们期望第三方的组件也可以共享这些状态和方法 inject 的注入逻辑我们重复编写了三次,如果可以的话,我们更希望只声明一次...,该模式能够提高 react 组件的复用程度和灵活性。...这样就解决了第三方组件无法共享其状态和方法的问题,在在线实例代码中,我实现了两个第三方组件,分别是 custom-button 和 custom-status-indicator,前者是自定义开关,使用...你可以通过下面的链接来看看这个组件的实现代码以及演示: sandbox: 在线演示 github: part-3 总结 mixin 作为一种分发 Vue 组件中可复用功能的非常灵活的方式,可以在很多场景下大展身手

44530

高级 Vue 组件模式 (9)

09 使用 Functional 组件 目标 到此为止,我们的 toggle 组件已经足够强大以及好用了,因此这篇文章不会再为它增加新的特性。...这听起来似乎有些耳熟啊,没错,它们就是在上一篇文章中所提及的木偶组件(Dump Component)。在 Vue 中,这种类型的组件也可以叫做函数式组件(Functional Component)。...实现 ToggleStatus 组件 接下来实现今天的主角,ToggleStatus 组件,由于我们的目标是将原先的二个函数式组件合二为一,因此这个组件本身应当也是一个函数式组件,不过我们需要使用另外一种写法...诸如 data 和 children 参数我们原封不动的传入 createElement 即可,因为这里对于 toggle-status 组件的定位是一个代理组件,对于其他参数以及子元素应当原封不动的传递给被代理的组件中...这种组件和普通组件相比的优势主要在于,它是无状态的,这意味着它的可测试性和可读性更好,同时一些情况下,渲染开销也更小。

59910

高级 Vue 组件模式 (5)

05 使用 $refs 访问子组件引用 目标 在之前的文章中,详细阐述了子组件获取父组件所提供属性及方法的一些解决方案,如果我们想在父组件之中访问子组件的一些方法和属性怎么办呢?...设想以下一个场景: 当前的 custom-button 组件中,有一个 input 元素 我们期望当 toggle 的开关状态为开时,显示 input 元素并自动获得焦点 这里要想完成目标,需要获取某个组件或者每个元素的引用...messages"> 注意这里的 ref="input",这样在组件内部,可以通过 this....同理,在 app 组件中,为 custom-button 添加一个 ref 属性,如下: 之后修改 onToggle 方法中的逻辑以满足目标中的需求,当 toggle 组件状态为开时,调用 custom-button 组件的 focus

54410

高级 Vue 组件模式 (8)

虽然父组件拥有了改变 toggle 组件内部状态的途径,但是如果进一步思考的话,父组件并没有绝对的控制权。在一些业务场景,我们期望父组件对于子组件的状态,拥有绝对的控制权。...对于后者,其父组件一定对其拥有绝对控制权,因为它内部没有状态,渲染逻辑完全取决于父组件所传 props 的值。...实现 判定组件是否受控 由于 toggle 组件为一个智能组件,我们需要提供一个判定它是否受控的方式。...false(开关状态为关)作为参数传入触发事件,这将告知父组件,当前组件的下一个状态为关,至于父组件是否同意将其状态更改为关则有父组件决定。...如果组件不受控,开关状态由组件内部自行管理,那和之前的实现逻辑是一模一样的,保留之前的代码即可。 成果 当 toggle 组件被改造后,实现这个需求就很容易了。

65510

高级 Angular 组件模式 (1)

组件的职责是仅仅是管理一个简单的布尔值状态属性: on。使用如此简单的组件进行说明的目的,是因为我们可以将更多的注意力投入到相对组件本身而言较复杂的模式中。...我们将从最原始的toggle组件版本开始。...它仅仅有一个使用了@Input()装饰器的on属性,这个属性所控制的状态代表组件本身的开关状态,同时它还有一个是使用了@Output()装饰器的toggle事件发射器,这个事件发射器会在组件开关状态改变的情况下...,通知父组件。...译者注 toggle组件的实现是一个很典型的利用单向数据流作为数据源的简单组件: on是单向数据源,同时代表组件内部的开关状态 toggle`是事件发射器`,以回调的方式将on状态的变化传递给父组件

63320

高级 Vue 组件模式 (7)

但我们会发现一个问题,就是当前 toggle 组件的状态对于调用者来说,完全是黑盒状态,即调用者无法初始化,也无法更改组件的开关状态,这在一些场景无法满足需求。...对于无法初始化开关状态的问题,倒是很好解决,我们可以在 toggle 组件声明一个 prop 属性 on 来代表组件的默认开关状态,同时在 mounted 生命周期函数中将这个默认值同步到组件 data...因此这篇文章着重来解决这两个问题: toggle 组件能够支持开关状态的初始化功能 toggle 组件能够提供一个 reset 方法以供重置开关状态 重置开关状态可以以异步的方式进行 实现 初始化开关状态... 重置开关状态 为了能够从外部更改 toggle 组件的开关状态,我们可以在组件内部声明一个观测 on prop 属性的监听器,比如: watch: { on(val){...这样就将提供重置状态的逻辑暴露给了组件调用者,当然,如果调用者没有提供相关重置逻辑,组件内部会自动降级为使用 on 属性来作为重置的状态值。

61310

高级 Angular 组件模式 (6)

组件作者提前了解使用该toggle组件的父组件所需要的状态时,那么它将会正常的运作。但是如果父组件所需要的状态并不在我们的设想之内,我们该怎么办?...目标 将toggle组件的状态直接提供给父组件,同时允许父组件提供相应的渲染视图(view)。 实现 组件可以完美地解决问题。 1....父组件 从toggle组件中传入的状态是通过let关键字在父组件的标签上显示声明的。...toggle>组件的模板作用域中的变量名。...除了上面的解决方法,就是使用正文中所提及的模式了,这种模式将子组件视图的渲染逻辑倒置为子组件仅仅声明模板中所会使用的状态变量,对于这些变量和模板的注入工作,全权赋予父组件,因此会使子组件的复用性和可测试性大大提高

1.1K20
领券