关于vue3的自定义hook

把一些逻辑写在单独的ts文件里,vue文件使用的时候引入即可

计算属性

1、方法1:return计算属性

直接写出去的话,使用时报错

ExpirationTime是一个计算属性,若直接在html上使用{{ExpirationTime(orderForm)}}报错

查阅资料显示:在 setup 函数中,调用 createExpirationTime 函数,并将 orderForm 作为参数传递。然后返回这个计算属性,以便在模板中使用。

setup声明在 <script> 标签内部。在这种情况下,你不需要显式地调用 setup 函数,而是可以直接定义响应式状态和计算属性

但是还是报错!!!!

最终代码

/*** 定义计算属性  计算续订之后的时间*/
import { computed } from 'vue'
import moment from 'moment'
import { orderTypeEnum } from '@/components/option.js'
export default function ExpirationTime(form) {return computed(() => {const date = moment(new Date())//如果存在时间,而且是包月计费if (form.duration && form.feeType == orderTypeEnum.MONTH) {//使用moment库的add方法return date.add(Number(form.duration), 'month').format('YYYY-MM-DD HH:mm:ss')//如果存在时间,而且是包年计费} else if (form.duration && form.feeType == orderTypeEnum.YEAR) {//使用moment库的add方法return date.add(Number(form.duration), 'year').format('YYYY-MM-DD HH:mm:ss')} else {return ''}})
}

需要return一个计算属性,这样在html中可以直接调用

2、方法二:将变量写在自定义hook里面

export default function aboutForm() {// 表单数据const orderForm = reactive({feeType: ''regionAndZone:''})/*** 计算属性计算到期时间*/const ExpirationTime = computed(() => {const date = moment(new Date())//如果存在时间,而且是包月计费if (orderForm.duration && orderForm.feeType == orderTypeEnum.MONTH) {//使用moment库的add方法return date.add(Number(orderForm.duration), 'month').format('YYYY-MM-DD HH:mm:ss')//如果存在时间,而且是包年计费} else if (orderForm.duration && orderForm.feeType == orderTypeEnum.YEAR) {//使用moment库的add方法return date.add(Number(orderForm.duration), 'year').format('YYYY-MM-DD HH:mm:ss')} else {return ''}})return {orderForm,ExpirationTime,}
}

vue文件里引入

import aboutForm from './hooks/aboutForm.ts'
const {orderForm, ExpirationTime} = aboutForm()

orderForm是全局变量,vue文件的其他函数也用到了这个变量。

全局变量是可以写在自定义hook里面的!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/564378.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【代码学习】Mediapipe人脸检测使用记录

Mediapipe&#xff0c;每秒200-300帧的实时人脸检测&#xff0c;提取画面中的人脸框&#xff0c;实现后续各种应用&#xff1a;人脸属性识别、表情识别、关键点检测、三维重建、增强现实、AI换妆等 code&#xff1a;google/mediapipe: Cross-platform, customizable ML soluti…

复旦EMBA参访娃哈哈:交流企业创新转型、家族企业管理之道

早在多年前&#xff0c;复旦EMBA同学曾参访娃哈哈集团&#xff0c;与宗庆后先生对话&#xff0c;就国内企业创新转型、家族企业管理之道、“企二代”的成长、企业社会责任等热点问题向其探讨交流。通过面对面的实地企业参访和行业领袖的深入交流&#xff0c;亲身触摸中国科创的…

结构体类型详细讲解(附带枚举,联合)

前言&#xff1a; 如果你还对结构体不是很了解&#xff0c;那么本篇文章将会从 为什么存在结构体&#xff0c;结构体的优点&#xff0c;结构体的定义&#xff0c;结构体的使用与结构体的大小依次介绍&#xff0c;同样会附带枚举与联合体 目录 为什么存在结构体&#xff1a; 结构…

手撕算法-删除有序数组中的重复项 II

描述 例如&#xff1a;输入&#xff1a;nums [1,1,1,2,2,3]输出&#xff1a;5, nums [1,1,2,2,3]解释&#xff1a;函数应返回新长度 length 5, 并且原数组的前五个元素被修改为 1, 1, 2, 2, 3。 不需要考虑数组中超出新长度后面的元素。 分析 双指针, fast, slow。nums[…

需求分析的过程

需求分析的工具 ominGraffle/Visio Gliffy ProcessOn RSA(UML) PPT/WORD 手绘 需求所需要的工件&#xff1a; 系统上下文、用例模型、质量限制 1.系统上下文的工件 2.用例模型工件&#xff08;什么功能&#xff09; 3.质量和限制 质量&#xff1a;管理10个小动物&#xff0c;…

【MySQL】2.MySQL数据库的基本操作

目录 数据库基本操作 查看数据库信息 查看数据库结构 显示数据表的结构&#xff08;字段&#xff09; 常用的数据类型 数据库管理操作 SQL语句概述 SQL分类 1.DDL&#xff1a;数据定义语言 1.1创建数据库和表 创建数据库 创建数据表 1.2删除数据库和表 删除数据表…

带3090显卡的Linux服务器上部署SDWebui

背景 一直在研究文生图&#xff0c;之前一直是用原始模型和diffuser跑SD模型&#xff0c;近来看到不少比较博主在用 SDWebui&#xff0c;于是想着在Linux服务器上部署体验一下&#xff0c;谁知道并没有想象的那么顺利&#xff0c;还是踩了不少坑。记录一下过程&#xff0c;也许…

Web框架开发-Ajax

一、 Ajax准备知识:json 1、json(Javascript Obiect Notation,JS对象标记)是一种轻量级的数据交换格式 1 2 它基于 ECMAScript (w3c制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。 简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。…

如何设计循环队列(两种方法)

文章目录 前言一、方法一:数组法二、方法二.链表法总结 前言 前面有提到过队列的知识&#xff0c;这次来说一下怎么设计一个循环队列 一.循环队列&#xff08;力扣&#xff09; . - 力扣&#xff08;LeetCode&#xff09;. - 备战技术面试&#xff1f;力扣提供海量技术面试资…

腾讯云服务器价格查询系统,2024年1年、3年和5年活动价格表

腾讯云服务器多少钱一年&#xff1f;61元一年起。2024年最新腾讯云服务器优惠价格表&#xff0c;腾讯云轻量2核2G3M服务器61元一年、2核2G4M服务器99元一年可买三年、2核4G5M服务器165元一年、3年756元、轻量4核8M12M服务器646元15个月、4核16G10M配置32元1个月、312元一年、8核…

Centos7 防火墙iptables?

Centos7 防火墙iptables&#xff1f; 文章目录 Centos7 防火墙iptables&#xff1f;1. 介绍2. firewalld 和 iptables区别3. 区域管理概念区域管理有如下几种不同的初始化区域&#xff1a; 4.iptables的配置1.简述2.基本原理3.iptables传输数据包的过程4. iptables规则表和链5.…

【自编码器】梳理(上)

every blog every motto: You can do more than you think. https://blog.csdn.net/weixin_39190382?typeblog 0. 前言 梳理有关自编码器 1. 自编码器 1.1 原理 Auto-Encoder&#xff0c;中文称作自编码器&#xff0c;是一种无监督式学习模型。利用输入数据 X X X本身作…