Vue笔记

vue实例

var data = {a: 1}
var vm = new Vue({
  el: '#app',
  router,
  data: data,
  components: {App},
  template: ''
})
vm.a = 5
console.log(vm.a === data.a)
  • 传进去的数值与外面的数值一直相等
  • 在外面添加的属性不会随之改变
  • 使用Object.freeze(obj)后在传进去的值不会被绑定
  • 前面带有$的函数一般是vue的属性或方法
    vm.$data //传进去的data vm.$el //组件的根节点 vm.$watch('a', function (newValue, oldValue) {}) //数据a改变之后触发的回调函数,不要使用剪头函数

生命周期

  • beforeCreatecreated
  • beforeMountmounted
  • beforeUpdateupdated
  • beforeDestroydestroyed

模板语法

  • <span>Message: {{ msg }}</span>
  • 只渲染一次<span v-once>{{ msg }}</span>
  • 输出html代码:<p>Using v-html directive: <span v-html="rawHtml"></span></p>
  • v-bind可以使用简单表达式,也可以为元素指定属性,如<a v-on:click="doSomething">...</a><a v-bind:href="url">...</a>
  • 也可以使用修饰符:<form v-on:submit.prevent="onSubmit">...</form>
  • 缩写: v-bind=>: , v-on=>@

计算属性

  • 可以理解为一个内部的方法,可以随时改变传入的data
  • 计算属性写在computed方法中
var vm = new Vue({
  el: '#example',
  data: {
    message: 'Hello'
  },
  computed: {
    // 计算属性的 getter
    reversedMessage: function () {
      // `this` 指向 vm 实例
      return this.message.split('').reverse().join('')
    }
  }
})
  • 计算属性使用缓存,方法不使用缓存,方法写在methods
  • 进行较大的开销的时候将函数写在watch中,可以理解为自动节流函数

class与style绑定

  • 使用v-bind控制class,v-bind中可以是一个数组,在data中指定数据,经常与计算属性连用
  • 会讲组件里面和外面的class属性一起添加
  • 使用v-bind也可以绑定内联属性,会自动添加浏览器前缀

条件渲染

  • 通过v-if控制元素是否显示,v-else必须紧跟在v-if的后面,也可以使用v-else-if
  • 也可以使用v-show,他不会在DOM中删除元素,只是控制元素不显示
  • v-for 具有比 v-if 更高的优先级。

列表渲染

  • v-for渲染列表,需要使用v-for="item in [array]"语法
  • 可以使用v-for="(item, index) in [array]"将数组的键名也加上
  • 如果是对象的话,使用v-for=value in [object]
  • 可以使用v-for="(value, key, index)in object"获取键名和序号
  • 使用push, pop, shift, unshift, splice, sort, reverse方法更改数组时,vue会自动监测并重新渲染
  • 使用索引直接设置和修改数组长度不会检测并渲染
  • 使用对象时,vue不会检测对象属性的添加或删除,但是可以使用Vue.set(object, key, value)为对象添加属性
  • 不使用计算属性更改数组,应该使用方法
  • 截取一段范围的v-for:<span v-for="n in 10">{{ n }} </span>
  • v-for 的优先级比 v-if 更高

事件处理

  • 使用v-on监听DOM事件,事件的处理方法写在method
  • 可以将$event作为参数传给方法,方法中可以调用原声事件对象
  • 使用修饰符达到一些目的:
    • .stop阻止单击事件继续传播
    • .prevent提交事件不再重载页面
    • .capture添加事件监听器时使用事件捕获模式
    • .self只处理自己触发的事件
    • .once处理事件只进行一次
    • .passive只要触发事件,立刻执行,不等事件完成
    • 使用的时候要注意顺序,可以串联使用
  • 按键修饰符
    • 可以使用.+数字,还有一些常用的按键
    • .enter, tab, delete, esc, space, up, down, left, right
    • 可以通过config.keyCodes设置按键别名
    • and so on ...不太常用

表单输入绑定

  • 使用model绑定表单元素,初始值为传入的data
  • 多个复选框应该绑定到同一个数组中
  • 多个单选按钮绑定到同一个变量中
  • 下拉框应该加一个禁用的请选择,以兼容ios
  • .lazy将每次都改变的model值设置为change
  • .number将用户输入的值转为数值
  • trim自动过滤首位空白字符

组件

  • 全局注册组件Vue.component('my-component', {})
  • 局部注册
var Child = {
  template: '<div>A custom component!</div>'
}

new Vue({
  // ...
  components: {
    // <my-component> 将只在父组件模板中可用
    'my-component': Child
  }
})
  • 组件的data必须是函数
  • 在一些规定内部标签的标签中使用<tr is="my-component"><tr/>来使用组件
  • 尽量使用字符串模板:<my-component my-message="hello"></my-comonent>
  • 使用props接收父元素传入的数据,传入的数据可以是一个数组或者对象
  • 父组件通过v-bind绑定传值,子组件不应该修改传入的props

Prop验证

props: {
    propA: Number, //基础类型检测
    required: true,  
    type: Object,
    default: 1,
    validator: function(value){} //自定义验证
}
  • type的值可以是String,Number,Boolean,Function,Object,Array,Symbol,也可以用instanceof检测
  • 先进行props检测,在进行组件注册

自定义事件

子组件给父组件传值

  • 父组件在使用子组件的时候绑定触发函数,将这个触发函数写进自己的方法中,子组件也可以有自己的方法
  • 父组件在调用子组件中写@[方法名]=[方法值],子元素触发在触发事件中写this.emit([方法名], '传递的数据')
  • .native给组件的跟元素加原生事件

非父子组件的通信

  • A组件:bus.$emit('id-selected', 1)
  • B组件:bus.$on('id-selected', function (id) { // ... })

插槽分发内容

  • 单个插槽

    如果父组件使用子组件,并在子组件中还加入了其他元素,那么应该在子元素中加入slot元素,如果父组件没有加入其他内容,那么将渲染slot中的html片段,如果加入了其他内容,则渲染其他内容。

  • 具名插槽

    如果父组件添加了两个slot元素,父组件通过slot=[名]指定子组件渲染的位置。子组件通过name=[名]来确认渲染位置。

  • 作用于插槽

    文档截图

动态组建

var vm = new Vue({
  el: '#example',
  data: {
    currentView: 'home'
  },
  components: {
    home: { /* ... */ },
    posts: { /* ... */ },
    archive: { /* ... */ }
  }
})

上述代码可以从当前代码选择一个子元素渲染,也可以直接用在组件对象上面

var Home = {
  template: '<p>Welcome home!</p>'
}

var vm = new Vue({
  el: '#example',
  data: {
    currentView: Home
  }
})

如果在外层家一个keep-alive元素,则在切换当前的子元素后,前一个子元素不会被清楚,而是放在内存中,可以保留他的状态或避免重新渲染。

杂项

  • 写组件的时候想好以后要不要进行复用
  • 进行使用v-bindv-on的简写:@
  • 给子组件加ref属性后可以使用父组件.ref属性值来调用子组件,当refv-for一起使用时,获取到的将是一个数组
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容

  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 11,012评论 4 129
  • VUE介绍 Vue的特点构建用户界面,只关注View层简单易学,简洁、轻量、快速渐进式框架 框架VS库库,是一封装...
    多多酱_DuoDuo_阅读 2,704评论 1 17
  • 1.基本绑定: new Vue( { el:'#elID', data:{ ...
    寒剑飘零阅读 529评论 0 1
  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,048评论 0 29
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,207评论 0 6