您好,欢迎来到五一七教育网。
搜索
您的当前位置:首页vue项目中watch的immediate使用

vue项目中watch的immediate使用

来源:五一七教育网


模板中p只能有一个,不能如上面那么平行2个p。

例如如下代码:

<template>
 <li
 v-for="route in routes"
 :key="route.name"
 >
 <router-link :to="route">
 {{ route.title }}
 </router-link>
 </li>
</template>

会报错!

我们可以用render函数来渲染

functional: true,
render(h, { props }) {
 return props.routes.map(route =>
 <li key={route.name}>
 <router-link to={route}>
 {route.title}
 </router-link>
 </li>
 )
}

七、组件包装、事件属性穿透问题

当我们写组件的时候,通常我们都需要从父组件传递一系列的props到子组件,同时父组件监听子组件emit过来的一系列事件。举例子:

//父组件
<BaseInput 
 :value="value"
 label="密码" 
 placeholder="请填写密码"
 @input="handleInput"
 @focus="handleFocus>
</BaseInput>
//子组件
<template>
 <label>
 {{ label }}
 <input
 :value="value"
 :placeholder="placeholder"
 @focus=$emit('focus', $event)"
 @input="$emit('input', $event.target.value)"
 >
 </label>
</template>

这样写很不精简,很多属性和事件都是手动定义的,我们可以如下写:

<input
 :value="value"
 v-bind="$attrs"
 v-on="listeners"
>
computed: {
 listeners() {
 return {
 ...this.$listeners,
 input: event => 
 this.$emit('input', event.target.value)
 }
 }
}

$attrs包含了父作用域中不作为 prop 被识别 (且获取) 的特性绑定 (class 和 style 除外)。当一个组件没有声明任何 prop 时,这里会包含所有父作用域的绑定,并且可以通过 v-bind="$attrs" 传入内部组件。

$listeners包含了父作用域中的 (不含 .native 修饰器的) v-on 事件。它可以通过 v-on="$listeners" 传入内部组件。

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

脚手架与热刷新、热加载

Vue怎样进行局部作用域 & 模块化

Copyright © 2019- 517ttc.cn 版权所有 赣ICP备2024042791号-8

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务