当前位置:   article > 正文

vue核心技术(二)

vue核心技术(二)

◆ 指令补充

指令修饰符

通过 "." 指明一些指令 后缀,不同 后缀 封装了不同的处理操作 → 简化代码

v-bind 对于样式控制的增强 

为了方便开发者进行样式控制, Vue 扩展了 v-bind 的语法,可以针对 class 类名 和 style 行内样式 进行控制 。

v-bind 对于样式控制的增强 - 操作class 

语法 :class = "对象/数组"

v-bind 对于样式控制的增强 - 操作style 

语法 :style = "样式对象"

v-model 应用于其他表单元素 

常见的表单元素都可以用 v-model 绑定关联 → 快速 获取 或 设置 表单元素的值

它会根据 控件类型 自动选取 正确的方法 来更新元素

简单来说就是使用v-model来给表单元素设置默认的初始值

 

 

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. <style>
  9. textarea {
  10. display: block;
  11. width: 240px;
  12. height: 100px;
  13. margin: 10px 0;
  14. }
  15. </style>
  16. </head>
  17. <body>
  18. <div id="app">
  19. <h3>小黑学习网</h3>
  20. 姓名:
  21. <input type="text" v-model="username">
  22. <br><br>
  23. 是否单身:
  24. <input type="checkbox" v-model="isSingle">
  25. <br><br>
  26. <!--
  27. 前置理解:
  28. 1. name: 给单选框加上 name 属性 可以分组 → 同一组互相会互斥
  29. 2. value: 给单选框加上 value 属性,用于提交给后台的数据
  30. 结合 Vue 使用 → v-model
  31. -->
  32. 性别:
  33. <input v-model="sex" type="radio" name="sex" value="0">
  34. <input v-model="sex"type="radio" name="sex" value="1">
  35. <br><br>
  36. <!--
  37. 前置理解:
  38. 1. option 需要设置 value 值,提交给后台
  39. 2. select 的 value 值,关联了选中的 option 的 value 值
  40. 结合 Vue 使用 → v-model
  41. -->
  42. 所在城市:
  43. <select v-model="cityId">
  44. <option value="100">北京</option>
  45. <option value="101">上海</option>
  46. <option value="102">成都</option>
  47. <option value="103">南京</option>
  48. </select>
  49. <br><br>
  50. 自我描述:
  51. <textarea v-model="description"></textarea>
  52. <button>立即注册</button>
  53. </div>
  54. <script src="./vue.js"></script>
  55. <script>
  56. const app = new Vue({
  57. el: '#app',
  58. data: {
  59. username: '',
  60. isSingle: true,
  61. sex: '1',
  62. cityId: '102',
  63. description: ''
  64. }
  65. })
  66. </script>
  67. </body>
  68. </html>

 

◆ computed 计算属性

概念:基于现有的数据,计算出来的新属性。 依赖的数据变化,自动重新计算。

语法:

① 声明在 computed 配置项中,一个计算属性对应一个函数
② 使用起来和普通属性一样使用 {{ 计算属性名 }}

计算属性 → 可以将一段 求值的代码 进行封装

computed 计算属性 vs methods 方法 

 

计算属性完整写法 (重点)

成绩案例 

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7. <link rel="stylesheet" href="./styles/index.css" />
  8. <title>Document</title>
  9. </head>
  10. <body>
  11. <div id="app" class="score-case">
  12. <div class="table">
  13. <table>
  14. <thead>
  15. <tr>
  16. <th>编号</th>
  17. <th>科目</th>
  18. <th>成绩</th>
  19. <th>操作</th>
  20. </tr>
  21. </thead>
  22. <tbody v-if="list.length > 0">
  23. <tr v-for="(item,index) in list" :key="item.id">
  24. <td>{{index+1}}</td>
  25. <td>{{item.subject}}</td>
  26. <td :class="{red: item.score<60}">{{item.score}}</td>
  27. <td><a @click.prevent="del(item.id)" href="#">删除</a></td>
  28. </tr>
  29. </tbody>
  30. <tbody v-else>
  31. <tr>
  32. <td colspan="5">
  33. <span class="none">暂无数据</span>
  34. </td>
  35. </tr>
  36. </tbody>
  37. <tfoot>
  38. <tr>
  39. <td colspan="5">
  40. <span>总分:{{total}}</span>
  41. <span style="margin-left: 50px">平均分:{{avg}}</span>
  42. </td>
  43. </tr>
  44. </tfoot>
  45. </table>
  46. </div>
  47. <div class="form">
  48. <div class="form-item">
  49. <div class="label">科目:</div>
  50. <div class="input">
  51. <input
  52. type="text"
  53. placeholder="请输入科目"
  54. v-model.trim="subject"
  55. />
  56. </div>
  57. </div>
  58. <div class="form-item">
  59. <div class="label">分数:</div>
  60. <div class="input">
  61. <input
  62. type="text"
  63. placeholder="请输入分数"
  64. v-model.number="score"
  65. />
  66. </div>
  67. </div>
  68. <div class="form-item">
  69. <div class="label"></div>
  70. <div class="input">
  71. <button class="submit" @click="add()">添加</button>
  72. </div>
  73. </div>
  74. </div>
  75. </div>
  76. <script src="../vue.js"></script>
  77. <script>
  78. const app = new Vue({
  79. el: '#app',
  80. data: {
  81. list: [
  82. { id: 1, subject: '语文', score: 20 },
  83. { id: 7, subject: '数学', score: 99 },
  84. { id: 12, subject: '英语', score: 70 },
  85. ],
  86. subject: '',
  87. score: ''
  88. },
  89. computed: {
  90. total(){
  91. // 使用数组求和函数
  92. return this.list.reduce((sum,item)=>sum+item.score,0)
  93. },
  94. avg(){
  95. if(this.list.length === 0){
  96. return 0
  97. }
  98. return (this.list.reduce((sum,item)=>sum+item.score,0)/this.list.length).toFixed(2)
  99. }
  100. },
  101. methods: {
  102. del(id){
  103. this.list = this.list.filter(item=>id!==item.id)
  104. },
  105. add(){
  106. if(!this.subject){
  107. alert('请输入科目名称!')
  108. return
  109. }
  110. console.log( typeof this.score );
  111. if( typeof this.score !=='number' || !(this.score >= 0 && this.score <=100)){
  112. alert('你输入的不是数字,或者分数不在0-100之间!')
  113. return
  114. }
  115. this.list.unshift({ id: +new Date(), subject: this.subject, score: this.score })
  116. }
  117. }
  118. })
  119. </script>
  120. </body>
  121. </html>

 

 

◆ watch 侦听器(重点)

作用:监视数据变化,执行一些 业务逻辑 或 异步操作。

语法:

① 简单写法 → 简单类型数据,直接监视

② 完整写法 → 添加额外配置项

简单写法

完整写法 

小结:

watch侦听器的语法有几种?

① 简单写法 → 监视简单类型的变化

 

② 完整写法 → 添加额外的配置项 (深度监视复杂类型,立刻执行)

 

◆ 综合案例:水果购物车

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7. <link rel="stylesheet" href="./css/inputnumber.css" />
  8. <link rel="stylesheet" href="./css/index.css" />
  9. <title>购物车</title>
  10. </head>
  11. <body>
  12. <div class="app-container" id="app">
  13. <!-- 顶部banner -->
  14. <div class="banner-box"><img src="./img/fruit.jpg" alt="" /></div>
  15. <!-- 面包屑 -->
  16. <div class="breadcrumb">
  17. <span>
    声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/blog/article/detail/96318
    推荐阅读
    相关标签