经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JSJS库框架 » JavaScript » 查看文章
Vue2 学习笔记1
来源:cnblogs  作者:王凯华  时间:2018/10/20 15:27:39  对本文有异议

什么是Vue.js

  • Vue.js 是目前最火的一个前端框架,React是最流行的一个前端框架(React除了开发网站,还可以开发手机App,Vue语法也是可以用于进行手机App开发的,需要借助于Weex)

  • Vue.js 是前端的主流框架之一,和Angular.js、React.js 一起,并成为前端三大主流框架!

  • Vue.js 是一套构建用户界面的框架,只关注视图层,它不仅易于上手,还便于与第三方库或既有项目整合。(Vue有配套的第三方类库,可以整合起来做大型项目的开发)

为什么要学习流行框架

  • 企业中,使用框架,能够提高开发的效率;
  • 提高开发效率的发展历程:原生JS -> Jquery之类的类库 -> 前端模板引擎 -> Angular.js / Vue.js(能够帮助我们减少不必要的DOM操作;提高渲染效率;双向数据绑定的概念【通过框架提供的指令,我们前端程序员只需要关心数据的业务逻辑,不再关心DOM是如何渲染的了】)
  • 在Vue中,一个核心的概念,就是让用户不再操作DOM元素,解放了用户的双手,让程序员可以更多的时间去关注业务逻辑;

Node(后端)中的 MVC 与 前端中的 MVVM 之间的区别

  • MVC 是后端的分层开发概念;
  • MVVM是前端视图层的概念,主要关注于 视图层分离,也就是说:MVVM把前端的视图层,分为了 三部分 Model, View , VM ViewModel
    01.MVC和MVVM的关系图解.png-74.6kB

Vue.js 基本代码 和 MVVM 之间的对应关系

  1. <body>
  2. <!-- 将来 new 的Vue实例,会控制这个 元素中的所有内容 -->
  3. <!-- Vue 实例所控制的这个元素区域,就是我们的 V -->
  4. <div id="app">
  5. <p>{{ msg }}</p>
  6. </div>
  7. <!-- 1. 导入Vue的包 -->
  8. <script src="./lib/vue-2.4.0.js"></script>
  9. <script>
  10. // 2. 创建一个Vue的实例
  11. // 当我们导入包之后,在浏览器的内存中,就多了一个 Vue 构造函数
  12. // 注意:我们 new 出来的这个 vm 对象,就是我们 MVVM中的 VM调度者
  13. var vm = new Vue({
  14. el: '#app', // 表示,当前我们 new 的这个 Vue 实例,要控制页面上的哪个区域
  15. // 这里的 data 就是 MVVM中的 M,专门用来保存 每个页面的数据的
  16. data: { // data 属性中,存放的是 el 中要用到的数据
  17. msg: '欢迎学习Vue' // 通过 Vue 提供的指令,很方便的就能把数据渲染到页面上,程序员不再手动操作DOM元素了【前端的Vue之类的框架,不提倡我们去手动操作DOM元素了】
  18. }
  19. })
  20. </script>
  21. </body>

Vue指令

Vue指令之插值表达式{{}} v-cloak v-textv-html

  1. <html lang="en">
  2. <head>
  3. <meta charset="UTF-8">
  4. <title>Document</title>
  5. <style>
  6. [v-cloak] {
  7. /* display: none; */
  8. }
  9. </style>
  10. </head>
  11. <body>
  12. <div id="app">
  13. <!-- 使用 v-cloak 能够解决 插值表达式闪烁的问题 -->
  14. <p v-cloak>++++++++ {{ msg }} ----------</p>
  15. <h4 v-text="msg">==================</h4>
  16. <!-- 默认 v-text 是没有闪烁问题的 -->
  17. <!-- v-text会覆盖元素中原本的内容,但是 插值表达式 只会替换自己的这个占位符,不会把 整个元素的内容清空 -->
  18. <div>{{msg2}}</div>
  19. <div v-text="msg2"></div>
  20. <div v-html="msg2">1212112</div>
  21. </div>
  22. <script src="./lib/vue-2.4.0.js"></script>
  23. <script>
  24. var vm = new Vue({
  25. el: '#app',
  26. data: {
  27. msg: '123',
  28. msg2: '<h1>哈哈,我是一个大大的H1, 我大,我骄傲</h1>',
  29. }
  30. })
  31. </script>
  32. </body>
  33. </html>

Vue指令之v-bind的三种用法

  1. 直接使用指令v-bind
  2. 使用简化指令:
  3. 在绑定的时候,拼接绑定内容::title="mytitle + ',这是追加的内容'"
  1. <body>
  2. <div id="app">
  3. <!-- v-bind: 是 Vue中,提供的用于绑定属性的指令 -->
  4. <input type="button" value="按钮" v-bind:title="mytitle + '这是追加的内容'">
  5. <!-- 注意: v-bind: 指令可以被简写为 :要绑定的属性 -->
  6. <!-- v-bind 中,可以写合法的JS表达式 -->
  7. <input type="button" value="按钮" :title="mytitle + '这是追加的内容'">
  8. </div>
  9. <script src="./lib/vue-2.4.0.js"></script>
  10. <script>
  11. var vm = new Vue({
  12. el: '#app',
  13. data: {
  14. mytitle: '这是一个自己定义的title'
  15. }
  16. })
  17. </script>
  18. </body>

Vue指令之v-on

  1. <body>
  2. <div id="app">
  3. <!-- Vue 中提供了 v-on: 事件绑定机制 ,简写@ -->
  4. <!--下面例子会报错 ,会把alert当做变量去data中寻找,找不到报错-->
  5. <!-- <input type="button" value="按钮" v-on:click="alert('hello')"> -->
  6. <input type="button" value="按钮" @click="show">
  7. </div>
  8. <script src="./lib/vue-2.4.0.js"></script>
  9. <script>
  10. var vm = new Vue({
  11. el: '#app',
  12. methods: { // 这个 methods属性中定义了当前Vue实例所有可用的方法
  13. show: function () {
  14. alert('Hello')
  15. }
  16. }
  17. })
  18. <!--原生js 操作dom实现-->
  19. /* document.getElementById('btn').onclick = function(){
  20. alert('Hello')
  21. } */
  22. </script>
  23. </body>

实现跑马灯效果

  1. HTML结构:
  1. <!-- 2. 创建一个要控制的区域 -->
  2. <div id="app">
  3. <input type="button" value="浪起来" @click="lang">
  4. <input type="button" value="低调" @click="stop">
  5. <h4>{{ msg }}</h4>
  6. </div>
  1. Vue实例:
  1. // 分析:
  2. // 1. 给 【浪起来】 按钮,绑定一个点击事件 v-on @
  3. // 2. 在按钮的事件处理函数中,写相关的业务逻辑代码:拿到 msg 字符串,然后 调用 字符串的 substring 来进行字符串的截取操作,把 第一个字符截取出来,放到最后一个位置即可;
  4. // 3. 为了实现点击下按钮,自动截取的功能,需要把 2 步骤中的代码,放到一个定时器中去;
  5. <script>
  6. // 注意:在 VM实例中,如果想要获取 data 上的数据,或者 想要调用 methods 中的 方法,必须通过 this.数据属性名 或 this.方法名 来进行访问,这里的this,就表示 我们 new 出来的 VM 实例对象
  7. var vm = new Vue({
  8. el: '#app',
  9. data: {
  10. msg: '猥琐发育,别浪~~!',
  11. intervalId: null // 在data上定义 定时器Id
  12. },
  13. methods: {
  14. lang() {
  15. // console.log(this.msg)
  16. // 获取到头的第一个字符
  17. // this
  18. if (this.intervalId != null) return;
  19. this.intervalId = setInterval(() => {
  20. var start = this.msg.substring(0, 1)
  21. // 获取到 后面的所有字符
  22. var end = this.msg.substring(1)
  23. // 重新拼接得到新的字符串,并赋值给 this.msg
  24. this.msg = end + start
  25. }, 400)
  26. // 注意: VM实例,会监听自己身上 data 中所有数据的改变,只要数据一发生变化,就会自动把 最新的数据,从data 上同步到页面中去;【好处:程序员只需要关心数据,不需要考虑如何重新渲染DOM页面】
  27. },
  28. stop() { // 停止定时器
  29. clearInterval(this.intervalId)
  30. // 每当清除了定时器之后,需要重新把 intervalId 置为 null
  31. this.intervalId = null;
  32. }
  33. }
  34. })
  35. </script>

事件修饰符

  • .stop 阻止冒泡
  • .prevent 阻止默认事件
  • .capture 添加事件侦听器时使用事件捕获模式
  • .self 只当事件在该元素本身(比如不是子元素)触发时触发回调
  • .once 事件只触发一次
  1. <head>
  2. <meta charset="UTF-8">
  3. <title>Document</title>
  4. <script src="./lib/vue-2.4.0.js"></script>
  5. <style>
  6. .inner {
  7. height: 150px;
  8. background-color: darkcyan;
  9. }
  10. .outer {
  11. padding: 40px;
  12. background-color: red;
  13. }
  14. </style>
  15. </head>
  16. <body>
  17. <div id="app">
  18. <!-- 使用 .stop 阻止冒泡 -->
  19. <!-- <div class="inner" @click="div1Handler">
  20. <input type="button" value="戳他" @click.stop="btnHandler">
  21. </div> -->
  22. <!-- 使用 .prevent 阻止默认行为 -->
  23. <!-- <a href="http://www.baidu.com" @click.prevent="linkClick">有问题,先去百度</a> -->
  24. <!-- 使用 .capture 实现捕获触发事件的机制 -->
  25. <!-- <div class="inner" @click.capture="div1Handler">
  26. <input type="button" value="戳他" @click="btnHandler">
  27. </div> -->
  28. <!-- 使用 .self 实现只有点击当前元素时候,才会触发事件处理函数 -->
  29. <!-- <div class="inner" @click="div1Handler">
  30. <input type="button" value="戳他" @click="btnHandler">
  31. </div> -->
  32. <!-- 使用 .once 只触发一次事件处理函数 -->
  33. <!-- <a href="http://www.baidu.com" @click.prevent.once="linkClick">有问题,先去百度</a> -->
  34. <!-- 演示: .stop 和 .self 的区别 -->
  35. <!-- <div class="outer" @click="div2Handler">
  36. <div class="inner" @click="div1Handler">
  37. <input type="button" value="戳他" @click.stop="btnHandler">
  38. </div>
  39. </div> -->
  40. <!-- .self 只会阻止自己身上冒泡行为的触发,并不会真正阻止 冒泡的行为 -->
  41. <!-- <div class="outer" @click="div2Handler">
  42. <div class="inner" @click.self="div1Handler">
  43. <input type="button" value="戳他" @click="btnHandler">
  44. </div>
  45. </div> -->
  46. </div>
  47. <script>
  48. // 创建 Vue 实例,得到 ViewModel
  49. var vm = new Vue({
  50. el: '#app',
  51. data: {},
  52. methods: {
  53. div1Handler() {
  54. console.log('这是触发了 inner div 的点击事件')
  55. },
  56. btnHandler() {
  57. console.log('这是触发了 btn 按钮 的点击事件')
  58. },
  59. linkClick() {
  60. console.log('触发了连接的点击事件')
  61. },
  62. div2Handler() {
  63. console.log('这是触发了 outer div 的点击事件')
  64. }
  65. }
  66. });
  67. </script>
  68. </body>

Vue指令之v-model双向数据绑定

  1. <body>
  2. <div id="app">
  3. <h4>{{ msg }}</h4>
  4. <!-- v-bind 只能实现数据的单向绑定,从 M 自动绑定到 V, 无法实现数据的双向绑定 -->
  5. <!-- <input type="text" v-bind:value="msg" style="width:100%;"> -->
  6. <!-- 使用 v-model 指令,可以实现 表单元素和 Model 中数据的双向数据绑定 -->
  7. <!-- 注意: v-model 只能运用在 表单元素中 -->
  8. <!-- input(radio, text, address, email....) select checkbox textarea -->
  9. <input type="text" style="width:100%;" v-model="msg">
  10. </div>
  11. <script>
  12. // 创建 Vue 实例,得到 ViewModel
  13. var vm = new Vue({
  14. el: '#app',
  15. data: {
  16. msg: '大家都是好学生,爱敲代码,爱学习,爱思考,简直是完美,没瑕疵!'
  17. },
  18. methods: {
  19. }
  20. });
  21. </script>
  22. </body>

简易计算器案例

  1. HTML 代码结构
  1. <div id="app">
  2. <input type="text" v-model="n1">
  3. <select v-model="opt">
  4. <option value="+">+</option>
  5. <option value="-">-</option>
  6. <option value="*">*</option>
  7. <option value="/">/</option>
  8. </select>
  9. <input type="text" v-model="n2">
  10. <input type="button" value="=" @click="calc">
  11. <input type="text" v-model="result">
  12. </div>
  1. Vue实例代码:
  1. <script>
  2. // 创建 Vue 实例,得到 ViewModel
  3. var vm = new Vue({
  4. el: '#app',
  5. data: {
  6. n1: 0,
  7. n2: 0,
  8. result: 0,
  9. opt: '+'
  10. },
  11. methods: {
  12. calc() { // 计算器算数的方法
  13. // 逻辑:
  14. /* switch (this.opt) {
  15. case '+':
  16. this.result = parseInt(this.n1) + parseInt(this.n2)
  17. break;
  18. case '-':
  19. this.result = parseInt(this.n1) - parseInt(this.n2)
  20. break;
  21. case '*':
  22. this.result = parseInt(this.n1) * parseInt(this.n2)
  23. break;
  24. case '/':
  25. this.result = parseInt(this.n1) / parseInt(this.n2)
  26. break;
  27. } */
  28. // 注意:这是投机取巧的方式,正式开发中,尽量少用
  29. var codeStr = 'parseInt(this.n1) ' + this.opt + ' parseInt(this.n2)'
  30. this.result = eval(codeStr)
  31. }
  32. }
  33. });
  34. </script>

在Vue中使用样式

使用class样式

  1. 数组
  2. 数组中使用三元表达式
  3. 数组中嵌套对象
  4. 直接使用对象
  1. <head>
  2. <meta charset="UTF-8">
  3. <title>Document</title>
  4. <script src="./lib/vue-2.4.0.js"></script>
  5. <style>
  6. .red {
  7. color: red;
  8. }
  9. .thin {
  10. font-weight: 200;
  11. .italic {
  12. font-style: italic;
  13. }
  14. .active {
  15. letter-spacing: 0.5em;
  16. }
  17. </style>
  18. </head>
  19. <body>
  20. <div id="app">
  21. <!-- <h1 class="red thin">这是一个很大很大的H1,大到你无法想象!!!</h1> -->
  22. <!-- 第一种使用方式,直接传递一个数组,注意: 这里的 class 需要使用 v-bind 做数据绑定 -->
  23. <!-- <h1 :class="['thin', 'italic']">这是一个很大很大的H1,大到你无法想象!!!</h1> -->
  24. <!-- 在数组中使用三元表达式 -->
  25. <!-- <h1 :class="['thin', 'italic', flag?'active':'']">这是一个很大很大的H1,大到你无法想象!!!</h1> -->
  26. <!-- 在数组中使用 对象来代替三元表达式,提高代码的可读性 -->
  27. <!-- <h1 :class="['thin', 'italic', {'active':flag} ]">这是一个很大很大的H1,大到你无法想象!!!</h1> -->
  28. <!-- 在为 class 使用 v-bind 绑定 对象的时候,对象的属性是类名,由于 对象的属性可带引号,也可不带引号,所以 这里我没写引号; 属性的值 是一个标识符 -->
  29. <h1 :class="classObj">这是一个很大很大的H1,大到你无法想象!!!</h1>
  30. </div>
  31. <script>
  32. // 创建 Vue 实例,得到 ViewModel
  33. var vm = new Vue({
  34. el: '#app',
  35. data: {
  36. flag: true,
  37. classObj: { red: true, thin: true, italic: false, active: false }
  38. },
  39. methods: {}
  40. });
  41. </script>
  42. </body>

使用内联样式

  1. 直接在元素上通过 :style 的形式,书写样式对象
  2. 将样式对象,定义到 data 中,并直接引用到 :style
  3. :style 中通过数组,引用多个 data 上的样式对象
  1. <body>
  2. <div id="app">
  3. <!-- 对象就是无序键值对的集合 -->
  4. <!-- <h1 :style="{ color: 'red', 'font-weight': 200 }">这是一个h1</h1> -->
  5. <!-- <h1 :style="styleObj1">这是一个h1</h1> -->
  6. <!--数组引用多个变量 -->
  7. <h1 :style="[ styleObj1, styleObj2 ]">这是一个h1</h1>
  8. </div>
  9. <script>
  10. // 创建 Vue 实例,得到 ViewModel
  11. var vm = new Vue({
  12. el: '#app',
  13. data: {
  14. /*书写规则 如果样式属性中间有 - 必须加引号*/
  15. styleObj1: { color: 'red', 'font-weight': 200 },
  16. styleObj2: { 'font-style': 'italic' }
  17. }
  18. });
  19. </script>
  20. </body>

Vue指令之v-forkey属性

  1. 迭代数组
  1. <div id="app">
  2. <!-- <p>{{list[0]}}</p>
  3. <p>{{list[1]}}</p>
  4. <p>{{list[2]}}</p>
  5. <p>{{list[3]}}</p>
  6. <p>{{list[4]}}</p> -->
  7. <p v-for="(item, i) in list">索引值:{{i}} --- 每一项:{{item}}</p>
  8. </div>
  9. <script>
  10. // 创建 Vue 实例,得到 ViewModel
  11. var vm = new Vue({
  12. el: '#app',
  13. data: {
  14. list: [1, 2, 3, 4, 5, 6]
  15. }
  16. });
  17. </script>
  18. ----------
  19. <body>
  20. <div id="app">
  21. <p v-for="(user, i) in list">Id:{{ user.id }} --- 名字:{{ user.name }} --- 索引:{{i}}</p>
  22. </div>
  23. <script>
  24. // 创建 Vue 实例,得到 ViewModel
  25. var vm = new Vue({
  26. el: '#app',
  27. data: {
  28. list: [
  29. { id: 1, name: 'zs1' },
  30. { id: 2, name: 'zs2' },
  31. { id: 3, name: 'zs3' },
  32. { id: 4, name: 'zs4' }
  33. ]
  34. },
  35. methods: {}
  36. });
  37. </script>
  38. </body>
  1. 迭代对象中的属性
  1. <body>
  2. <div id="app">
  3. <!-- 注意:在遍历对象身上的键值对的时候, 除了 有 val key ,在第三个位置还有 一个 索引 -->
  4. <p v-for="(val, key, i) in user">值是: {{ val }} --- 键是: {{key}} -- 索引: {{i}}</p>
  5. </div>
  6. <script>
  7. // 创建 Vue 实例,得到 ViewModel
  8. var vm = new Vue({
  9. el: '#app',
  10. data: {
  11. user: {
  12. id: 1,
  13. name: '托尼·屎大颗',
  14. gender: '男'
  15. }
  16. },
  17. methods: {}
  18. });
  19. </script>
  20. </body>
  1. 迭代数字
  1. <body>
  2. <div id="app">
  3. <!-- in 后面我们放过 普通数组,对象数组,对象, 还可以放数字 -->
  4. <!-- 注意:如果使用 v-for 迭代数字的话,前面的 count 值从 1 开始 -->
  5. <p v-for="count in 10">这是第 {{ count }} 次循环</p>
  6. </div>
  7. <script>
  8. // 创建 Vue 实例,得到 ViewModel
  9. var vm = new Vue({
  10. el: '#app',
  11. data: {},
  12. methods: {}
  13. });
  14. </script>
  15. </body>

v-for指令使用注意事项

  1. <div id="app">
  2. <div>
  3. <label>Id:
  4. <input type="text" v-model="id">
  5. </label>
  6. <label>Name:
  7. <input type="text" v-model="name">
  8. </label>
  9. <input type="button" value="添加" @click="add">
  10. </div>
  11. <!-- 注意: v-for 循环的时候,key 属性只能使用 number获取string -->
  12. <!-- 注意: key 在使用的时候,必须使用 v-bind 属性绑定的形式,指定 key 的值 -->
  13. <!-- 在组件中,使用v-for循环的时候,或者在一些特殊情况中,如果 v-for 有问题,必须 在使用 v-for 的同时,指定 唯一的 字符串/数字 类型 :key 值 -->
  14. <p v-for="item in list" :key="item.id">
  15. <input type="checkbox">{{item.id}} --- {{item.name}}
  16. </p>
  17. </div>
  18. <script>
  19. // 创建 Vue 实例,得到 ViewModel
  20. var vm = new Vue({
  21. el: '#app',
  22. data: {
  23. id: '',
  24. name: '',
  25. list: [
  26. { id: 1, name: '李斯' },
  27. { id: 2, name: '嬴政' },
  28. { id: 3, name: '赵高' },
  29. { id: 4, name: '韩非' },
  30. { id: 5, name: '荀子' }
  31. ]
  32. },
  33. methods: {
  34. add() { // 添加方法
  35. this.list.unshift({ id: this.id, name: this.name })
  36. }
  37. }
  38. });
  39. </script>
  40. </body>

2.2.0+ 的版本里,当在组件中使用 v-for 时,key是必须的。
当 Vue.js 用 v-for 正在更新已渲染过的元素列表时,它默认用 “就地复用” 策略。如果数据项的顺序被改变,Vue将不是移动 DOM 元素来匹配数据项的顺序, 而是简单复用此处每个元素,并且确保它在特定索引下显示已被渲染过的每个元素。

为了给 Vue 一个提示,以便它能跟踪每个节点的身份,从而重用和重新排序现有元素,你需要为每项提供一个唯一 key 属性。

Vue指令之v-ifv-show

一般来说,v-if 有更高的切换消耗而 v-show 有更高的初始渲染消耗。因此,如果需要频繁切换 v-show 较好,如果在运行时条件不大可能改变 v-if 较好。

  1. <body>
  2. <div id="app">
  3. <!-- <input type="button" value="toggle" @click="toggle"> -->
  4. <input type="button" value="toggle" @click="flag=!flag">
  5. <!-- v-if 的特点:每次都会重新删除或创建元素 -->
  6. <!-- v-show 的特点: 每次不会重新进行DOM的删除和创建操作,只是切换了元素的 display:none 样式 -->
  7. <!-- v-if 有较高的切换性能消耗 -->
  8. <!-- v-show 有较高的初始渲染消耗 -->
  9. <!-- 如果元素涉及到频繁的切换,最好不要使用 v-if, 而是推荐使用 v-show -->
  10. <!-- 如果元素可能永远也不会被显示出来被用户看到,则推荐使用 v-if -->
  11. <h3 v-if="flag">这是用v-if控制的元素</h3>
  12. <h3 v-show="flag">这是用v-show控制的元素</h3>
  13. </div>
  14. <script>
  15. // 创建 Vue 实例,得到 ViewModel
  16. var vm = new Vue({
  17. el: '#app',
  18. data: {
  19. flag: false
  20. },
  21. methods: {
  22. /* toggle() {
  23. this.flag = !this.flag
  24. } */
  25. }
  26. });
  27. </script>
  28. </body>
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号