青岛达内it培训 > 达内新闻
v-on可以监听多个方法吗,key的作用?
- 发布:青岛IT培训
- 来源:青岛IT培训
- 时间:2019-04-15 16:46
青岛IT培训的小编总结, 问题一:v-on可以监听多个方法吗?
v-on可以监听多个方法,例如:
<input type=“text” :value=“name” @input=“onInput” @focus=“onFocus” @blur=“onBlur” />
但是同一种事件类型的方法,vue-cli工程会报错,例如:
<a href=“javascript:;” @click=“methodsOne” @click=“methodsTwo”></a>
问题二:vue中 key 值的作用
key值:用于 管理可复用的元素。因为Vue 会尽可能高效地渲染元素,通常会复用已有元素而不是从头开始渲染。这么做使 Vue 变得非常快,但是这样也不总是符合实际需求。
2.2.0+ 的版本里,当在组件中使用 v-for 时,key 现在是必须的。
例如,如果你允许用户在不同的登录方式之间切换:
<template v-if=“loginType === 'username‘”>
<label>Username</label>
<input placeholder=“Enter your username”>
</template>
<template v-else>
<label>Email</label>
<input placeholder=“Enter your email address”>
</template>
那么在上面的代码中切换loginTypeloginType 将不会清除用户已经输入的内容。因为两个模板使用了相同的元素,</span>不会被替换掉,仅仅是替换了它的 placeholder`.
这样也不总是符合实际需求,所以Vue为你提供了一种方式来表达这两个元素是完全独立的,不要复用它们。只需添加一个具有唯一值的 key 属性即可:
<template v-if=“loginType === 'username’”>
<label>Username</label>
<input placeholder=“Enter your username” key=“username-input”>
</template>
<template v-else>
<label>Email</label>
<input placeholder=“Enter your email address” key=“email-input”>
</template>

现在,每次切换时,输入框都将被重新渲染。
注意,渲染列表的组件需要v-bind绑定,缩写:key=“xx”.
<my-component
v-for=“(item, index) in items”
v-bind:item=“item”
v-bind:index=“index”
v-bind:key=“item.id”
></my-component>
以上就是青岛IT培训给大家做的内容详解,更多关于UI的学习,请继续关注青岛IT培训
最新开班时间
- 北京
- 上海
- 广州
- 深圳
- 南京
- 成都
- 武汉
- 西安
- 青岛
- 天津
- 杭州
- 重庆
- 哈尔滨
- 济南
- 沈阳
- 合肥
- 郑州
- 长春
- 苏州
- 长沙
- 昆明
- 太原
- 无锡
- 石家庄
- 南宁
- 佛山
- 珠海
- 宁波
- 保定
- 呼和浩特
- 洛阳
- 烟台
- 运城
- 潍坊
v-on可以监听多个方法吗,key的作用?
- 发布:青岛IT培训
- 来源:青岛IT培训
- 时间:2019-04-15 16:46
青岛IT培训的小编总结, 问题一:v-on可以监听多个方法吗?
v-on可以监听多个方法,例如:
<input type=“text” :value=“name” @input=“onInput” @focus=“onFocus” @blur=“onBlur” />
但是同一种事件类型的方法,vue-cli工程会报错,例如:
<a href=“javascript:;” @click=“methodsOne” @click=“methodsTwo”></a>
问题二:vue中 key 值的作用
key值:用于 管理可复用的元素。因为Vue 会尽可能高效地渲染元素,通常会复用已有元素而不是从头开始渲染。这么做使 Vue 变得非常快,但是这样也不总是符合实际需求。
2.2.0+ 的版本里,当在组件中使用 v-for 时,key 现在是必须的。
例如,如果你允许用户在不同的登录方式之间切换:
<template v-if=“loginType === 'username‘”>
<label>Username</label>
<input placeholder=“Enter your username”>
</template>
<template v-else>
<label>Email</label>
<input placeholder=“Enter your email address”>
</template>
那么在上面的代码中切换loginTypeloginType 将不会清除用户已经输入的内容。因为两个模板使用了相同的元素,</span>不会被替换掉,仅仅是替换了它的 placeholder`.
这样也不总是符合实际需求,所以Vue为你提供了一种方式来表达这两个元素是完全独立的,不要复用它们。只需添加一个具有唯一值的 key 属性即可:
<template v-if=“loginType === 'username’”>
<label>Username</label>
<input placeholder=“Enter your username” key=“username-input”>
</template>
<template v-else>
<label>Email</label>
<input placeholder=“Enter your email address” key=“email-input”>
</template>

现在,每次切换时,输入框都将被重新渲染。
注意,渲染列表的组件需要v-bind绑定,缩写:key=“xx”.
<my-component
v-for=“(item, index) in items”
v-bind:item=“item”
v-bind:index=“index”
v-bind:key=“item.id”
></my-component>
以上就是青岛IT培训给大家做的内容详解,更多关于UI的学习,请继续关注青岛IT培训
最新开班时间
- 北京
- 上海
- 广州
- 深圳
- 南京
- 成都
- 武汉
- 西安
- 青岛
- 天津
- 杭州
- 重庆
- 厦门
- 哈尔滨
- 济南
- 福州
- 沈阳
- 合肥
- 郑州
- 长春
- 苏州
- 大连
- 长沙
- 昆明
- 温州
- 太原
- 南昌
- 无锡
- 石家庄
- 南宁
- 中山
- 兰州
- 佛山
- 珠海
- 宁波
- 贵阳
- 保定
- 呼和浩特
- 东莞
- 洛阳
- 潍坊
- 烟台
- 运城