首页 > 语言 > JavaScript > 正文

Vue2.2.0+新特性整理及注意事项

2024-05-06 15:31:18
字体:
来源:转载
供稿:网友

大家对vue的基本概念了解吗?不太清楚的朋友可以先熟悉下。

vue基础教程

Vue.js(读音 /vjuː/, 类似于 view) 是一套构建用户界面的渐进式框架。
Vue 只关注视图层, 采用自底向上增量开发的设计。
Vue 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

本文给大家整理了vue2.2.0+新特征并详细的给大家罗列了各个版本的注意要点。这是本文重点要讲的知识,大家可以参考学习。

先附上官网: https://cn.vuejs.org/v2/guide/

2.2.0+版本

v-for

2.2.0+ 的版本里,当在组件中使用  v-for 时, key 现在是必须的。

鼠标修饰符

.left
.right
.middle

这些修饰符会限制处理函数仅响应特定的鼠标按钮。

model

允许一个自定义组件在使用 v-model 时定制 prop 和 event。默认情况下,一个组件上的  v-model 会把  value 用作 prop 且把  input 用作 event,但是一些输入类型比如单选框和复选框按钮可能想使用  value prop 来达到不同的目的。使用  model 选项可以回避这些情况产生的冲突。

Vue.component('my-checkbox', { model: { prop: 'checked', event: 'change' }, props: { // this allows using the `value` prop for a different purpose value: String, // use `checked` as the prop which take the place of `value` checked: { type: Number, default: 0 } }, data:function(){ return{ _value:this.value } }, template:` <input   type="checkbox"   v-bind:checked="checked"  v-on:change="$emit('change',$event.target.checked)"  ></input>`  // ...})<my-checkbox v-model="foo" value="some value"></my-checkbox>

上述代码相当于:

<my-checkbox :checked="foo" @change="val => { foo = val }" value="some value"></my-checkbox>

注:checked属性要声明在props中

provide/inject

这对选项需要一起使用,以允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在起上下游关系成立的时间里始终生效。

https://cn.vuejs.org/v2/api/#provide-inject

2.3.0版本

绑定内联样式

从 2.3.0 起你可以为 style 绑定中的属性提供一个包含多个值的数组,常用于提供多个带前缀的值,例如:

<div :style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }"></div>
这样写只会渲染数组中最后一个被浏览器支持的值。在本例中,如果浏览器支持不带浏览器前缀的 flexbox,那么就只会渲染

display: flex

事件修饰符

Vue 还对应 addEventListener  中的  passive  选项 提供了  .passive 修饰符。

<!-- 滚动事件的默认行为 (即滚动行为) 将会立即触发 --><!-- 而不会等待 `onScroll` 完成 --><!-- 这其中包含 `event.preventDefault()` 的情况 --><div v-on:scroll.passive="onScroll">...</div>            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选