• Vue实例学习过程中碰到的小问题


    在使用插值表达式{{  }}取data中list数组中的值时把整个表达式当做文本显示了,原因不明,但是使用v-text替换插值表达式之后问题得到解决.

    原因已经查明,因为第78行,定义对象car时后面不小心加了个逗号,导致对象读取出现问题,前面的插值表达式读不到相应的数据所以把整个表达式当做文本显示.

    var car = { id:this.id , name:this.name , ctime:new Date()},
    //万恶的逗号
     1 <!DOCTYPE html>
     2 <html>
     3     <head>
     4         <meta charset="utf-8">
     5         <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
     6         <meta http-equiv="X-UA-Compatible" content="ie=edge"/>
     7         <title>Document</title>
     8         <script src="lib/vue-2.4.0.js"></script>
     9         <link rel="stylesheet" type="text/css" href="lib/bootstrap-3.3.7.css"/>
    10         <!-- 需要用到JQuery吗? -->
    11         <!-- JQuery本质是使用js进行查询,是对dom的操作,而在Vue中尽量避免对dom进行操作 -->
    12     </head>
    13     <body>
    14         <div id="app">
    15             
    16             <div class="panel panel-primary">
    17                 <div class="panel-heading">
    18                     <h3 class="panel-title">添加品牌</h3>
    19                 </div>
    20                 <div class="panel-body form-inline">
    21                     <label>
    22                         ID:
    23                         <input type="text" class="form-control" v-model="id"/>
    24                         <!-- 这里的id是data中的id,不是list中的id -->
    25                     </label>
    26                     <label>
    27                         Name:
    28                         <input type="text" class="form-control" v-model="name"/>
    29                         <!-- 这里的name是data中的name,不是list中的name -->
    30                     </label>
    31                     <!-- 在Vue中使用事件绑定机制,为元素制定处理函数时,如果加了小括号,就可以给函数传参了 -->
    32                     <input type="button" value="添加" class="btn btn-primary" @click="add()"/>
    33                 </div>
    34                 
    35             </div>
    36             
    37             
    38     
    39             <table class="table table-bordered table-hover table-striped">
    40                 <thead>
    41                     <tr>
    42                         <th>Id</th>
    43                         <th>Name</th>
    44                         <th>Ctime</th>
    45                         <th>Operation</th>
    46                     </tr>
    47                 </thead>
    48                 <tbody>
    49                     <tr v-for="item in list" :key="item.id">
    50                         <td v-text="item.id"></td>
    51                         <td v-text="item.name"></td>
    52                         <td v-text="item.ctime"></td>
    53                         <td>
    54                             <a href="">删除</a>
    55                         </td>
    56                     </tr>
    57                 </tbody>
    58             </table>
    59         </div>
    60         <script type="text/javascript">
    61             var vm = new Vue({    
    62                 el:'#app',    
    63                 data:{ 
    64                     id:'',
    65                     name:'',
    66                     list:[
    67                         { id:1 , name: '奔驰' , ctime: new Date() },
    68                         { id:2 , name: '宝马' , ctime: new Date() },
    69                     ]
    70                 },    
    71                 methods:{    
    72                      add(){    //添加的方法
    73                          // 分析:
    74                          // 1.获取到id和name,直接从data上获取
    75                          // 2.组织出一个对象
    76                          // 3.把这个对象,调用数组的相关方法,添加到当前data上的list中
    77                          // 4.注意:在Vue中已经实现了数据的双向绑定,每当我们修改了data中的数据.Vue会监听到数据的改动,自动把最新的数据应用到页面上
    78                          var car = { id:this.id , name:this.name , ctime:new Date()}
    79                          this.list.push(car)
    80                          this.id = this.name = ''
    81                      }
    82                 }
    83             })
    84         </script>
    85     </body>
    86 </html>
  • 相关阅读:
    idea设置全局ignore
    win 2012 安装mysql 5.7.20 及报错 This application requires Visual Studio 2013 Redistributable. Please ins
    win 2012 安装mysql 5.7.20 及报错 This application requires Visual Studio 2013 Redistr
    kafka 删除 topic
    java编译中出现了Exception in thread “main" java.lang.UnsupportedClassVersionError
    Centos中使用yum安装java时,没有jps的问题的解决
    Spring 整合Junit
    Spring纯注解配置
    Spring 基于注解的 IOC 配置
    打印java系统的信息
  • 原文地址:https://www.cnblogs.com/edward-life/p/10757195.html
Copyright © 2020-2023  润新知