• Javaweb之Vue指令案例的详细解析


    2.3.5 案例

    • 需求:

    • 如上图所示,我们提供好了数据模型,users是数组集合,提供了多个用户信息。然后我们需要将数据以表格的形式,展示到页面上,其中,性别需要转换成中文男女,等级需要将分数数值转换成对应的等级。
    • 分析:

      首先我们肯定需要遍历数组的,所以需要使用v-for标签;然后我们每一条数据对应一行,所以v-for需要添加在tr标签上;其次我们需要将编号,所以需要使用索引的遍历语法;然后我们要将数据展示到表格的单元格中,所以我们需要使用{{}}插值表达式;最后,我们需要转换内容,所以我们需要使用v-if指令,进行条件判断和内容的转换

    • 步骤:

      • 使用v-for的带索引方式添加到表格的标签上

      • 使用{{}}插值表达式展示内容到单元格

      • 使用索引+1来作为编号

      • 使用v-if来判断,改变性别和等级这2列的值

    • 代码实现:

      首先创建名为17. Vue-指令-案例.html的文件,提前准备如下代码:

      1. 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>Vue-指令-案例title>
      8.    <script src="js/vue.js">script>
      9. head>
      10. <body>
      11.    
      12.    <div id="app">
      13.        
      14.        <table border="1" cellspacing="0" width="60%">
      15.            <tr>
      16.                <th>编号th>
      17.                <th>姓名th>
      18.                <th>年龄th>
      19.                <th>性别th>
      20.                <th>成绩th>
      21.                <th>等级th>
      22.            tr>
      23.        table>
      24.    div>
      25. body>
      26. <script>
      27.    new Vue({
      28.        el: "#app",
      29.        data: {
      30.            users: [{
      31.                name: "Tom",
      32.                age: 20,
      33.                gender: 1,
      34.                score: 78
      35.           },{
      36.                name: "Rose",
      37.                age: 18,
      38.                gender: 2,
      39.                score: 86
      40.           },{
      41.                name: "Jerry",
      42.                age: 26,
      43.                gender: 1,
      44.                score: 90
      45.           },{
      46.                name: "Tony",
      47.                age: 30,
      48.                gender: 1,
      49.                score: 52
      50.           }]
      51.       },
      52.        methods: {
      53.            
      54.       },
      55.   })
      56. script>
      57. html>

      然后在上添加v-for进行遍历,以及通过插值表达式{{}}和v-if指令来填充内容和改变内容,其代码如下:

      1. <tr align="center" v-for="(user,index) in users">
      2.     <td>{{index + 1}}td>
      3.     <td>{{user.name}}td>
      4.     <td>{{user.age}}td>
      5.     <td>
      6.         <span v-if="user.gender == 1">span>
      7.         <span v-if="user.gender == 2">span>
      8.     td>
      9.     <td>{{user.score}}td>
      10.     <td>
      11.         <span v-if="user.score >= 85">优秀span>
      12.         <span v-else-if="user.score >= 60">及格span>
      13.         <span style="color: red;" v-else>不及格span>
      14.     td>
      15. tr>

    其完整代码如下:

    1. 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>Vue-指令-案例title>
    8.    <script src="js/vue.js">script>
    9. head>
    10. <body>
    11.    
    12.    <div id="app">
    13.        
    14.        <table border="1" cellspacing="0" width="60%">
    15.            <tr>
    16.                <th>编号th>
    17.                <th>姓名th>
    18.                <th>年龄th>
    19.                <th>性别th>
    20.                <th>成绩th>
    21.                <th>等级th>
    22.            tr>
    23.            <tr align="center" v-for="(user,index) in users">
    24.                <td>{{index + 1}}td>
    25.                <td>{{user.name}}td>
    26.                <td>{{user.age}}td>
    27.                <td>
    28.                    <span v-if="user.gender == 1">span>
    29.                    <span v-if="user.gender == 2">span>
    30.                td>
    31.                <td>{{user.score}}td>
    32.                <td>
    33.                    <span v-if="user.score >= 85">优秀span>
    34.                    <span v-else-if="user.score >= 60">及格span>
    35.                    <span style="color: red;" v-else>不及格span>
    36.                td>
    37.            tr>
    38.        table>
    39.    div>
    40. body>
    41. <script>
    42.    new Vue({
    43.        el: "#app",
    44.        data: {
    45.            users: [{
    46.                name: "Tom",
    47.                age: 20,
    48.                gender: 1,
    49.                score: 78
    50.           },{
    51.                name: "Rose",
    52.                age: 18,
    53.                gender: 2,
    54.                score: 86
    55.           },{
    56.                name: "Jerry",
    57.                age: 26,
    58.                gender: 1,
    59.                score: 90
    60.           },{
    61.                name: "Tony",
    62.                age: 30,
    63.                gender: 1,
    64.                score: 52
    65.           }]
    66.       },
    67.        methods: {
    68.            
    69.       },
    70.   })
    71. script>
    72. html>

  • 相关阅读:
    AtCoder Beginner Contest 258 A~H 题解
    【论文解读】Parameter-Efficient Transfer Learning for NLP
    STM32FATFS文件系统移植
    JAVA设计模式3:抽象工厂模式,这是一种创建型设计模式
    java并发面试题
    Mybatis深入:整合框架
    java-php-python-ssm新冠疫苗接种预约系统登录计算机毕业设计
    sequence如何接收来自driver的transaction
    前端导入导出
    springboot蓝球场馆预约系统毕业设计-附源码211706
  • 原文地址:https://blog.csdn.net/qq_69748833/article/details/134485108