zoukankan      html  css  js  c++  java
  • 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>
  • 相关阅读:
    python类的特殊成员和方法
    python 之 staticmethod,classmethod,property的区别
    启动Android模拟器问题集锦
    eclipse编译Jmeter源码
    解决 'chromedriver' executable needs to be in PATH.'报错
    登录程序优化
    通过标志位跳出多层循环
    crontab计划任务监控nginx服务器
    httpstatus类的状态有哪些
    python正则表达式
  • 原文地址:https://www.cnblogs.com/edward-life/p/10757195.html
Copyright © 2011-2022 走看看