WEB前端13-Vue2常用指令

打印 上一主题 下一主题

主题 807|帖子 807|积分 2421

Vue2常用指令

1. 文本插值

Vue 中使用双大括号 {{ }} 进行文本插值,将数据渲染到 DOM 中:
  1. <template>
  2.     <div>
  3.         <h1>{{ name }}</h1>
  4.         <h1>{{ age > 60 ? '老年' : '青年' }}</h1>
  5.     </div>
  6. </template>
  7. <script>
  8. const options = {
  9.     data: function () {
  10.         return {
  11.             name: '张三',
  12.             age: 20
  13.         };
  14.     }
  15. };
  16. export default options;
  17. </script>
复制代码
注意事项和细节:


  • 文本插值支持简朴的 JavaScript 表达式,但不保举在插值中使用复杂逻辑或方法调用。
  • Vue 实例的 data 对象中定义的属性会相应式地更新视图,即当 message 改变时,相干的 DOM 会主动更新,默认为双向绑定。
  • {{}} 里只能绑定一个属性,绑定多个属性需要用多个 {{}} 分别绑定
  • Vue中还设置了v-text和v-html标签用于替换文档的内容,它与Js中的textContent和innerHTML属性的作用相同
2. 属性绑定

可以使用 v-bind 指令来动态绑定 HTML 属性:
  1. <template>
  2.   <div>
  3.     <img v-bind:src="imageURL">
  4.   </div>
  5. </template>
  6. <script>
  7. export default {
  8.   data() {
  9.     return {
  10.       imageURL: 'https://example.com/image.jpg'
  11.     };
  12.   }
  13. };
  14. </script>
复制代码
注意事项和细节:


  • v-bind 可以简写为 :,例如 :src="imageURL"。
  • 动态绑定的属性可以是 HTML 元素的任何属性,比如 href、class 等。
3. 事件绑定

使用 v-on 指令来监听 DOM 事件:
  1. <template>
  2.   <div>
  3.     <button @click="sayHello">Say Hello</button>
  4.   </div>
  5. </template>
  6. <script>
  7. export default {
  8.   methods: {
  9.     sayHello() {
  10.       alert('Hello!');
  11.     }
  12.   }
  13. };
  14. </script>
复制代码
注意事项和细节:


  • v-on 可以简写为 @,例如 @click="sayHello"。
  • 在 methods 中定义的方法可以在模板中通过 v-on 绑定到事件上,如许可以实现用户交互。
  • 在 methods 方法中的 this 代表的是 data 函数返回的数据对象
4. 双向绑定

使用 v-model 指令实现表单位素的双向绑定:
  1. <template>
  2.   <div>
  3.     <input v-model="message" type="text">
  4.     <p>{{ message }}</p>
  5.   </div>
  6. </template>
  7. <script>
  8. export default {
  9.   data() {
  10.     return {
  11.       message: '你好'
  12.     };
  13.   }
  14. };
  15. </script>
复制代码
注意事项和细节:


  • v-model 只实用于表单位素,如 input、textarea 和 select。
  • 双向绑定会将输入框的值与 Vue 实例的数据属性同步,从而实现数据的双向活动。
  • 复选框这种标签,双向绑定的 javascript 数据类型一般用数组
5. 盘算属性

通过 computed 属性定义盘算属性,根据依赖进行缓存,只有在相干依赖发生厘革时才会重新盘算:
  1. <!-- 计算属性 -->
  2. <template>
  3.         <div>
  4.       显示全名:{{ fullName() }}<br />
  5.       显示全名:{{ fullName1 }}<br />
  6.     </div>
  7. </template>
  8. <script>
  9. const options = {
  10.     data: function () {
  11.         return { xing: '李', ming: '四' };
  12.     },
  13.     methods: {
  14.         fullName() {
  15.       return this.xing + this.ming;}
  16.     },
  17.     computed: {
  18.         fullName1() {
  19.       return this.xing + this.ming;}
  20.     },
  21. };
  22. export default options;
  23. </script>
复制代码
注意事项和细节:


  • 普通方法调用必须加 (),没有缓存功能
  • 盘算属性使用时就把它当属性来用,不加 (),有缓存功能:一次盘算后,会将效果缓存,下次再盘算时,只要数据没有厘革,不会重新盘算,直接返回缓存效果
6.条件渲染

v-if 和 v-else
v-if 是Vue.js中用来根据表达式的真假条件渲染元素的指令。它的基本用法如下:
  1. <div v-if="condition">
  2.   <!-- 当条件为真时显示的内容 -->
  3. </div>
复制代码
此中,condition 是一个返回布尔值的表达式。如果 condition 为真,<div> 元素及其内容会被渲染到页面上;如果 condition 为假,则 <div> 元素不会被渲染。
有时候,我们需要在条件为假的情况下显示备选内容,这时可以使用 v-else:
  1. <div v-if="condition">
  2.   <!-- 当条件为真时显示的内容 -->
  3. </div>
  4. <div v-else>  <!-- 当条件为假时显示的内容 --></div>
复制代码
v-else 指令必须紧跟在带有 v-if 的元素大概 v-if / v-else-if 块的后面,并且在同一父元素下。它表现,如果前面的 v-if 表达式为假,则渲染 v-else 后面的内容。


  • 注意:v-if现实就是根据表达式的布尔值对dom树中的节点进行增删,类似的v-show下令是通过display属性,根据表达式的布尔值动态展示
7.列表渲染

v-for 是Vue.js中用来渲染列表数据的指令,它能够根据数据源迭代渲染出多个元素。基本的用法如下:
  1. <div v-for="item in items" :key="item.id">
  2.   {{ item.name }}
  3. </div>
复制代码
在这个例子中,items 是一个包罗多个对象的数组,每个对象都至少有一个唯一的 id 属性。v-for 指令会遍历 items 数组,为每个数组元素创建一个 <div> 元素,并显示 item.name 的内容。
注意事项:


  • v-for 指令后面需要使用 in 关键字来指定遍历的源数据大概使用关键字of
  • 必须为每个迭代的元素提供一个唯一的 key 属性,以便于Vue.js识别每个节点的身份,优化渲染性能。
案例:动态表格

后端:
  1. package com.tyut.controller;
  2. import com.fasterxml.jackson.databind.ObjectMapper;
  3. import com.tyut.entity.Student;
  4. import com.tyut.service.StudentService;
  5. import javax.servlet.ServletException;
  6. import javax.servlet.annotation.WebServlet;
  7. import javax.servlet.http.HttpServlet;
  8. import javax.servlet.http.HttpServletRequest;
  9. import javax.servlet.http.HttpServletResponse;
  10. import java.io.IOException;
  11. import java.io.PrintWriter;
  12. import java.util.List;
  13. @WebServlet("/getStudentsServlet")
  14. public class GetStudentsServlet extends HttpServlet {
  15.     @Override
  16.     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  17.         response.setContentType("text/html;charset=utf-8");
  18.         response.addHeader("Access-Control-Allow-Origin", "http://localhost:7070");
  19.         request.setCharacterEncoding("utf-8");
  20.         PrintWriter out = response.getWriter();
  21.         StudentService studentService = new StudentService();
  22.         List<Student> allStudent = studentService.getAllStudent();
  23.         // 创建 ObjectMapper 对象
  24.         ObjectMapper objectMapper = new ObjectMapper();
  25.         // 将集合转换为 JSON 字符串
  26.         String jsonString = objectMapper.writeValueAsString(allStudent);
  27.         out.write(jsonString);
  28.     }
  29.     @Override
  30.     protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  31.         this.doGet(request, response);
  32.     }
  33. }
复制代码
前端:
  1. <template>
  2.   <div>
  3.     <div>
  4.       <table>
  5.         <caption>
  6.           学生信息表
  7.         </caption>
  8.         <thead>
  9.           <tr>
  10.             <th>编号</th>
  11.             <th>姓名</th>
  12.             <th>性别</th>
  13.           </tr>
  14.         </thead>
  15.         <tbody v-if="students.length > 0">
  16.           <tr v-for="s in students" :key="s.id">
  17.             <td>{{ s.id }}</td>
  18.             <td>{{ s.name }}</td>
  19.             <td>{{ s.sex }}</td>
  20.           </tr>
  21.         </tbody>
  22.         <tbody v-else>
  23.           <tr>
  24.             <td colspan="3" class="message">暂无学生数据</td>
  25.           </tr>
  26.         </tbody>
  27.       </table>
  28.     </div>
  29.     <div v-text="students"></div>
  30.     <div>{{ students }}</div>
  31.   </div>
  32. </template>
  33. <script>
  34. import axios from "axios";
  35. export default {
  36.   data() {
  37.     return {
  38.       students: [],
  39.     };
  40.   },
  41.   mounted() {
  42.     this.getStudents();
  43.   },
  44.   methods: {
  45.     async getStudents() {
  46.       try {
  47.         const response = await axios.post("/management_system/getStudentsServlet");
  48.         this.students = response.data;
  49.       } catch (error) {
  50.         console.error("Error fetching students:", error);
  51.       }
  52.     },
  53.   },
  54. };
  55. </script>
  56. <style scoped>
  57. caption {
  58.   text-align: center;
  59.   font-family: "腾讯体";
  60.   font-size: 50px;
  61. }
  62. table {
  63.   border: 2px solid silver;
  64.   margin: 0 auto; /* 设置左右外边距为自动,实现居中 */
  65.   width: 50%; /* 可根据需要调整宽度 */
  66.   border-spacing: 0;
  67. }
  68. th,
  69. td {
  70.   border: 1px solid silver;
  71.   width: 100px;
  72.   height: 50px;
  73.   font-family: "黑体";
  74.   font-size: 25px;
  75.   text-align: center;
  76. }
  77. .message {
  78.   text-align: center;
  79. }
  80. </style>
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

瑞星

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表