Vue3第二章(computed的使用)

computed()方法可以传一个函数return,也可以传一个对象,实现这个对象的get和set方法

入门案例

<template>
  <div>
   <input type="text" v-model="firstNmae">
   <input type="text" v-model="lastNmae">
   <div>
    {{name}}
   </div>
  </div>
</template>

<script setup lang="ts">
import {ref,computed} from 'vue'

let firstNmae = ref('')
let lastNmae = ref('')


// computed写法1
// let name = computed(()=>{
//   return firstNmae.value + '----' + lastNmae.value
// })

// computed写法2
let name = computed({
  get(){
    return firstNmae.value + '----' + lastNmae.value
  },
  set(){
    firstNmae.value + '----' + lastNmae.value
  }
})
</script>

购物车案例

<template>
  <div>
    <table border style="width:500px">
      <thead>
        <tr>
          <th>名称</th>
          <th>数量</th>
          <th>价格</th>
          <th>操作</th>
        </tr>
      </thead>
      <tbody>
        <tr :key="index" v-for="(item,index) in data">
          <td>{{item.name}}</td>
          <td><button @click="addAndSub(item,false)">-</button>{{item.num}}<button @click="addAndSub(item,true)">+</button></td>
          <td>{{item.price * item.num}}</td>
          <td><button @click="del(index)">删除</button></td>
        </tr>
      </tbody>
      <tfoot>
        <td></td>
        <td></td>
        <td></td>
        <td>总计:{{$total}}</td>
      </tfoot>
    </table>
  </div>
</template>

<script setup lang="ts">
import { ref, reactive, computed } from "vue";
let $total = ref(0)
type Shop = {
  name: string,
  num: number,
  price: number
}
const data = reactive<Shop[]>([
  {
    name: '满神的裤子',
    num: 1,
    price: 100
  },
  {
    name: '满神的鞋子',
    num: 1,
    price: 200
  },
  {
    name: '满神的丝袜',
    num: 1,
    price: 300
  }
])

const addAndSub = (item:Shop,type:boolean) => {
  if(item.num > 1 && !type){
    item.num--;
  }
  if(item.num < 99 && type){
    item.num++;
  }
}

const del = (index:number) => {
  data.splice(index,1)
}

$total = computed<number>(()=> {
  return data.reduce((prev,next)=>{
    return prev + (next.num + next.price)
  },0)
})
</script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值