vue指令

  <!-- 主体区域 -->
  <section id="app">
    <!-- 输入框 -->
    <header class="header">
      <h1>记事本</h1>
      <input v-model="todoName" placeholder="请输入任务" class="new-todo" />
      <button @click="add()" class="add">添加任务</button>
    </header>
    <!-- 列表区域 -->
    <section class="main">
      <ul class="todo-list">
        <li class="todo" v-for="(item ,index) in list" :key="item.id">
          <div class="view">
            <span class="index">{{ index + 1 }}.</span> <label>{{ item.name }}</label>
            <button @click="del(item.id)" class="destroy"></button>
          </div>
        </li>
      </ul>
    </section>
    <!-- 统计和清空 -->
    <footer v-show="list.length > 0" class="footer">
      <!-- 统计 -->
      <span class="todo-count">合 计:<strong> {{ this.list.length }} </strong></span>
      <!-- 清空 -->
      <button @click="clear()" class="clear-completed">
        清空任务
      </button>
    </footer>
  </section>

  <!-- 底部 -->
   
  <script>

    const app = new Vue({
      el: '#app',
      data: {
        todoName:'',
        list: [
          { id: 1, name: '吃饭' },
          { id: 2, name: '睡觉' },
        ]
      },
      methods: {
        del (id) {
          this.list = this.list.filter(item => item.id !== id)
        },
        
        add () {
          if (this.todoName.trim() === '') {
            alert('请输入任务名称')
            return
          }
          this.list.unshift({
            id: +new Date(), 
            name: this.todoName
          })
          this.todoName = ''
        },

        clear () {
          this.list = []
        }
      }
    })

  </script>

0be5e33d4b294486bbde5a98856dc4dd.jpg

 

arr.unshift(  )  添加到数组开头

用时间戳表示唯一的id

app.list

app=this    →  this.list

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值