当前位置: 首页 > article >正文

“代驾”小程序查漏补缺

vue3&part

watch

官方文档:https://cn.vuejs.org/api/reactivity-core.html#watch

功能:侦听一个或多个响应式数据源,并在数据源变化时调用所给的回调函数。

watch(
  () => tabName.value,
  (val) => {
    appType.value = tabsList.value[val]?.id
    paging.value.reload()
  },
)

watchEffect

官方文档:https://cn.vuejs.org/api/reactivity-core.html#watch

功能:立即运行一个函数,同时响应式地追踪其依赖,并在依赖更改时重新执行。

 学到这里的时候,在会去复习一下vue3的md文档(名字叫vue3快速上手)

computed

官方文档:响应式 API:核心 | Vue.js

功能:接受一个 getter 函数,返回一个只读的响应式 ref 对象。该 ref 通过 .value 暴露 getter 函数的返回值。它也可以接受一个带有 get 和 set 函数的对象来创建一个可写的 ref 对象。

// 计算选中单品列表
const selectedCartList = computed(() => {
  return cartList.value.filter((v) => v.selected)
})

// 计算选中总件数
const selectedCartListCount = computed(() => {
  return selectedCartList.value.reduce((sum, item) => sum + item.count, 0)
})

// 计算选中总金额
const selectedCartListMoney = computed(() => {
  return selectedCartList.value
    .reduce((sum, item) => sum + item.count * item.nowPrice, 0)
    .toFixed(2)
})

store

官方文档:定义 Store | Pinia

功能:Pinia 是 Vue 的专属状态管理库,它允许你跨组件或页面共享状态。

import { defineStore } from "pinia"
import { ref } from "vue"

export const useUserStore = defineStore(
  "user",  //第一个参数 这个字符串 "user" 是 store 的唯一标识符(ID)。在 Pinia 中,每个 store 必须具有唯一的 ID,以便在应用中区分不同的 store。
  () => {   //第二个参数 store 的状态和方法
    const userInfo = ref<Partial<IUserInfo> | null>()

    const setUserInfo = (val: IUserInfo) => {
      userInfo.value = val
    }

    const clearUserInfo = () => {
      userInfo.value = null
    }
    // 一般没有reset需求,不需要的可以删除
    const reset = () => {
      userInfo.value = null
    }
    const isLogined = computed(() => !!userInfo.value?.jwt)

    return {
      userInfo,
      setUserInfo,
      clearUserInfo,
      isLogined,
      reset,
    }
  },
  { //第三个参数 store 的配置选项
    persist: true,
// 用来配置是否将 store 的状态持久化到浏览器的 localStorage 或 sessionStorage
  },
)

Loash

官方文档:Lodash 简介 | Lodash中文文档 | Lodash中文网

防抖

官方文档:lodash.debounce | Lodash中文文档 | Lodash中文网

// 记得引入
import _ from "lodash"
// 使用 debounce 包装 getQuestion
const debouncedGetQuestion = _.debounce((value) => getQuestion(value), 300)
// 输入
const onChange = ({ value }) => {
  isQuestion.value = true
  value = value.trim()
  if (!value) {
    onClear()
    return
  }
  debouncedGetQuestion(value) // 使用封装后的函数
}
// 查询
const onSearch = ({ value }) => {
  isQuestion.value = true
  value = value.trim()
  if (!value) {
    onClear()
    keyword.value = ""
    return
  }
  debouncedGetQuestion(value) // 使用封装后的函数
}

 节流

官方文档:lodash.throttle | Lodash中文文档 | Lodash中文网

 uniapp的生命周期

官方文档:App.vue/App.uvue | uni-app官网

http&接口请求方法

 

// 分页查询常见问题列表
export const postQuestionList = (pageNum, pageSize, data) => {
  return http.post<questionListItem>(`/biz/question/questionList/${pageNum}/${pageSize}`, data)
}

 


http://www.kler.cn/a/504110.html

相关文章:

  • 导出文件,能够导出但是文件打不开
  • 智能化植物病害检测:使用深度学习与图像识别技术的应用
  • 项目概述、开发环境搭建(day01)
  • 【C++】PP5015 [NOIP2018 普及组] 标题统计
  • .NET framework、Core和Standard都是什么?
  • FastDDS安装测试记录
  • 【漫话机器学习系列】048.编码有序类别特征(Encoding Ordinal Categorical Features)
  • C#里使用libxl设置EXCEL里公式计算的例子
  • Golang——并发控制
  • macos遇到You have not agreed to the Xcode license agreements.
  • SpringBoot之OriginTrackedPropertiesLoader类源码学习
  • 网管平台(进阶篇):路由器的管理实践
  • 华三S6520交换机配置console和ssh
  • 【数据结构学习笔记】19:跳表(Skip List)
  • 浅谈计算机网络02 | SDN控制平面
  • 一个使用 Golang 编写的新一代网络爬虫框架,支持JS动态内容爬取
  • 【漫话机器学习系列】047.指数型线性单元(Exponential Linear Units,ELU)
  • 1.4 给应用添加service,执行扩容和滚动更新
  • TDSQL 内存占用解析一例
  • Golang|单机并发缓存
  • 24. 【.NET 8 实战--孢子记账--从单体到微服务】--记账模块--预算扣除、退回、补充
  • 华为2024嵌入式研发面试题
  • Adobe与MIT推出自回归实时视频生成技术CausVid。AI可以边生成视频边实时播放!
  • Oracle 终止正在执行的SQL
  • 下载导出Tomcat上的excle文档,浏览器上显示下载
  • Web前端------HTML块级和行内标签之块级标签