vue.js学习记录

文章已同步我的github笔记https://github.com/ymblog/blog,欢迎大家加star~~

vue实例

生命周期

beforeCreate:不能访问this.$el和this.$data用于初始化非响应式变量
created:可以访问this.$data,不能访问到this.$el属性,this.$refs内容,用于ajax请求,created里赋值,data不用定义
beforeMount:this.$el和this.$data都初始化了,挂载前this.$el的值为'虚拟'的元素节点,比较少使用
mounted:'虚拟'的Dom节点被真实的Dom节点替换,用于获取VNode信息和操作,this.$refs可以访问
beforeupdate:响应式数据更新时调用,发生在虚拟DOM打补丁之前
updated:虚拟 DOM 重新渲染和打补丁之后调用,组件DOM已经更新,data数据变化时只会触发update
beforeDestroy:实例销毁之前调用。这一步,实例仍然完全可用,this仍能获取到实例,用于销毁定时器、解绑全局事件、销毁插件对象等操作
destroyed:实例销毁后调用,调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁

指令

指令带有 v- 前缀的特殊属性

v-html

解释:更新DOM对象的textContent,为了输出真正的 HTML
还有v-on、v-bind、v-model、v-for、v-if、v-else、v-else-if不展开说明
注意:v-if 与 v-for 一起使用时,v-for 具有比 v-if 更高的优先级
v-if和v-show的区别:v-show适合非常频繁地切换

修饰符

事件修饰符:


  1. .stop 阻止冒泡,调用 event.stopPropagation()
  2. .prevent 阻止默认行为,调用 event.preventDefault()
  3. .once事件只触发一次

按键修饰符:
@keyup.enter……
表单修饰符:
.lazy、.number、.trim

key

推荐:使用 v-for 的时候提供 key 属性,以获得性能提升
说明:使用 key,VUE会基于 key 的变化重新排列元素顺序,并且会移除 key 不存在的元素,vue会复用已有元素,使用两个input切换会共用,需要使用key让其独立

Class 与 Style 绑定

表达式的类型:字符串、数组、对象(重点)


  1. //1
  2. <div v-bind:class="{ active: true }"></div> ===> 解析后
  3. <div class="active"></div>
  4. //2
  5. <div v-bind:class="[{ active: true }, errorClass]"></div> ===>解析后
  6. <div class="active text-danger"></div>

组件

prop

定义组件名kebab-case或者PascalCase(自己使用)


  1. //使用prop来传值:
  2. //子组件html
  3. <template>
  4. <header class="ly-header">
  5. <span>{{title}}</span>
  6. </header>
  7. </template>
  8. //js
  9. props:['content','value']
  10. 进行验证,type类型有:NumberStringBooleanArrayObject
  11. propA: {
  12. type: Number,
  13. default: 100
  14. }
  15. //父组件html
  16. <header :title="我是标题">

注意:父级组件<comp some-prop="1"></comp>1为字符串,使用:some-prop="1",1为数字

通过事件向父级组件发送消息

推荐始终使用 kebab-case 的事件名
$emit方法并传入事件的名字,来向父级组件触发一个事件


  1. //子级
  2. &lt;template&gt;
  3. &lt;div class="header" @click="$emit('say-event')"&gt;点击我&lt;/div&gt;
  4. &lt;/template&gt;
  5. //父级
  6. &lt;template&gt;
  7. &lt;Header :content="content" @say-event="sayHanle"&gt;&lt;/Header&gt;
  8. &lt;/template&gt;
  9. &lt;script&gt;
  10. import Header from '@/components/header';
  11. export default{
  12. methods:{
  13. sayHanle(){
  14. console.log(222);
  15. }
  16. }
  17. }
  18. &lt;/script&gt;

动态组件-is


  1. //currentTabComponent改变,组件也随之改变
  2. &lt;component v-bind:is="currentTabComponent"&gt;&lt;/component&gt;

插槽-slot

说明:通过<slot></slot> 标签指定内容展示区域


  1. //子级定义
  2. &lt;template&gt;
  3. &lt;div class="header"&gt;
  4. &lt;slot name="title"&gt;&lt;/slot&gt;
  5. &lt;slot name="desc"&gt;&lt;/slot&gt;
  6. &lt;/div&gt;
  7. &lt;/template&gt;
  8. //父级
  9. &lt;Header&gt;
  10. &lt;p slot="desc" class="desc"&gt;我的描述&lt;/p&gt;
  11. &lt;/Header&gt;

自定义指令

作用:进行DOM操作


  1. //全局定义
  2. Vue.directive('focus', {
  3. inserted: function (el) {
  4. el.focus()
  5. }
  6. }

钩子函数
bind:指令第一次绑定到元素时调用
inserted:被绑定元素插入父节点时调用
unbind:只调用一次,指令与元素解绑时调用

过滤器

作用:文本数据格式化


  1. //全局过滤器
  2. &lt;div&gt;{{ dateStr | date }}&lt;/div&gt;
  3. &lt;div&gt;{{ dateStr | date('YYYY-MM-DD hh:mm:ss') }}&lt;/div&gt;
  4. &lt;script&gt;
  5. Vue.filter('date', function(value, format) {
  6. // value 要过滤的字符串内容,比如:dateStr
  7. // format 过滤器的参数,比如:'YYYY-MM-DD hh:mm:ss'
  8. })
  9. &lt;/script&gt;
  10. //局部过滤器
  11. filters: {
  12. filterName: function(value, format) {}
  13. }

监视数据变化-watch

作用:当表达式的值发生变化后,会调用对应的回调函数完成响应的监视操作


  1. watch:{
  2. info:function(val,oldVal){
  3. console.log('当前值为:' + val, '旧值为:' + oldVal)
  4. }
  5. }
  6. 选项包括有三个
  7. 第一个是handler:其值是一个回调函数,即监听到变化时应该执行的函数。
  8. 第二个是deep:其值是truefalse,确认是否深入监听。(一般监听时是不能监听到对象属性值的变化的,数组的值变化可以听到)
  9. 第三个是immediate:其值是truefalse,确认是否以当前的初始值执行handler的函数。

结束,撒花~~~

文章已同步我的github笔记https://github.com/ymblog/blog,欢迎大家加star~~

来源:https://segmentfault.com/a/1190000016551191

vue.js学习记录的更多相关文章

  1. Js 框架之Vue .JS学习记录 ① 与Vue 初识

    目录 与 Vue.js 认识 VUE.JS是个啥?有啥好处? Vue 的目标 战前准备  VUE.JS环境 VUE.JS 尝试一下,你就明白 第一步 实例化VUE 对象 第二步VueAPP 调用数据 ...

  2. Vue.js学习笔记(2)vue-router

    vue中vue-router的使用:

  3. 我的three.js学习记录(二)

    通过上一篇文章我的three.js学习记录(一)基本上是入门了three.js,但是这不够3D,这次我希望能把之前做的demo弄出来,然后通过例子来分析操作步骤. 1. 示例 上图是之前做的一个dem ...

  4. 我的three.js学习记录(三)

    此次的亮点不是three.js的3d部分,而是通过调用摄像头然后通过摄像头的图像变化进行简单的判断后进行一些操作.上篇中我通过简单的示例分析来学习three.js,这次是通过上一篇的一些代码来与摄像头 ...

  5. vue.js 学习笔记3——TypeScript

    目录 vue.js 学习笔记3--TypeScript 工具 基础类型 数组 元组 枚举 字面量 接口 类类型 类类型要素 函数 函数参数 this对象和类型 重载 迭代器 Symbol.iterat ...

  6. vue.js学习资料

    vue.js学习VuejsAPI教程 https://vuejs.org.cn/guide/Vuejs自己的构建工具 http://www.jianshu.com/p/f8e21d87a572如何用v ...

  7. Vue.js学习笔记:在元素 和 template 中使用 v-if 指令

    f 指令 语法比较简单,直接上代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" " ...

  8. vue.js学习之better-scroll封装的轮播图初始化失败

    vue.js学习之better-scroll封装的轮播图初始化失败 问题一:slider组件初始化失败 原因:页面异步获取数据很慢,导致slider初始化之后,数据还未获取到,导致图片还未加载 解决方 ...

  9. vue.js学习之 跨域请求代理与axios传参

    vue.js学习之 跨域请求代理与axios传参 一:跨域请求代理 1:打开config/index.js module.exports{ dev: { } } 在这里面找到proxyTable{}, ...

随机推荐

  1. node.js入门学习(一)环境安装,REPL,fs模块,path模块,http模块

    一.node.js介绍 1.1.node.js是什么 官网首页总结:Node.js® 是一个基于 Chrome V8 引擎 的 JavaScript 运行时. 1)node.js是一个开发平台,就像j ...

  2. java+web+大文件上传下载

    文件上传是最古老的互联网操作之一,20多年来几乎没有怎么变化,还是操作麻烦.缺乏交互.用户体验差. 一.前端代码 英国程序员Remy Sharp总结了这些新的接口 ,本文在他的基础之上,讨论在前端采用 ...

  3. codevs 1057 津津的储蓄计划 2004年NOIP全国联赛提高组 x

     时间限制: 1 s  空间限制: 128000 KB   题目描述 Description 津津的零花钱一直都是自己管理.每个月的月初妈妈给津津300元钱,津津会预算这个月的花销,并且总能做到实际花 ...

  4. 在Sublime Text 3中配置Python3的开发环境/Build System

    本文来源:https://www.cnblogs.com/zhangqinwei/p/6886600.html Sublime Text作为一款支持多种编程语言的文本编辑神器,深受广大开发者的喜爱.通 ...

  5. event.stopPropagation()和event.preventDefault(),return false的区别

    我写公司的官网遇到一个问题,轮播图的上一层有一块内容,用鼠标拖动那块内容的时候下一层的轮播图也会跟着拖动,而上面的那层的内容是不会动的,我想这就是冒泡事件在作祟了吧 跟冒泡事件相关的,我想到三个: 1 ...

  6. 技术干货:Python解析CSV

    1. 什么是CSV CSV(Commma-Separated Value)是都好分隔符,其文件以纯文本形式存储表格数据(数字和文本). 案例: 2. 为什么要使用CSV 与专有的二进制文件格式截然不同 ...

  7. Vim 命令、操作、快捷键(收藏大全)

    ------ 命令历史 以:和/开头的命令都有历史纪录,可以首先键入:或/然后按上下箭头来选择某个历史命令. 启动vim 在命令行窗口中输入以下命令即可 vim 直接启动vim vim filenam ...

  8. Spring Boot教程(十七)属性配置文件详解(2)

    通过命令行设置属性值 相信使用过一段时间Spring Boot的用户,一定知道这条命令:java -jar xxx.jar --server.port=8888,通过使用–server.port属性来 ...

  9. css实现不定宽高的div水平、垂直居中

    一共有三个方案: 1,第一种方案主要使用了css3中transform进行元素偏移,效果非常好 这方法功能很强大,也比较灵活,不仅仅局限在实现居中显示.  兼容方面也一样拿IE来做比较,第二种方法IE ...

  10. route Cmd详解

    第一条命令,配置外网网关: route -p add 0.0.0.0 mask 0.0.0.0 192.168.1.1 第二条命令,配置内网网关:route -p add 192.168.0.0 ma ...