位置: IT常识 - 正文

Vue 3.x基础(vue3.0用法)

编辑:rootadmin
Vue 3.x基础 模版 <template> // html </template> <script setup> // setup API // ... </script> <style> // css </style> setup API 变量(响应式) // 基本数据类型 let refVa ... Vue 3.x基础模版<template> // html</template><script setup> // setup API // ...</script><style> // css</style>setup API

推荐整理分享Vue 3.x基础(vue3.0用法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3官方教程,vue3.0教程,vue3.0入门教程,vue 3 教程,vue3 入门,vue3.0教程,vue3 入门,vue3.0教程,内容如对您有帮助,希望把文章链接给更多的朋友!

Vue 3.x基础(vue3.0用法)

变量(响应式)

// 基本数据类型let refValue = ref(1)console.log(refValue.value) // 1// 复杂数据类型let reactiveValue = reactive({ a: 1, b: 2 })console.log(reactiveValue) // { a: 1, b: 2 }// 解构toRefs,一般用于reacative创建的变量const { a, b } = toRefs(reactiveValue)console.log(a, b) // 1, 2

函数

// 创建const changeValue = (v) => { refValue.value = v console.log(v) // 1}// 调用changeValue(1)生命周期选项式 APISetup API调用时机beforeCreateNot needed*#createdNot needed*#beforeMountonBeforeMount(常用)在挂载开始之前被调用:相关的 render 函数首次被调用。mountedonMounte(常用)组件挂载时调用beforeUpdateonBeforeUpdate数据更新之前调用,此时DOM还未更新updatedonUpdatedDOM 重新渲染和打补丁,此时DOM已更新,不要在该钩子函数里更新数据。beforeUnmountonBeforeUnmount在卸载组件实例之前调用。此时Vue实例仍是正常的。unmountedonUnmounted卸载组件实例后调用,组件实例的所有指令、事件侦听器都被移、子组件实例都会被卸载。activatedonActivated被 keep-alive 缓存的组件激活时调用。deactivatedonDeactivated被 keep-alive 缓存的组件停用时调用。errorCapturedonErrorCaptured当捕获一个来自子孙组件的错误时被调用,此钩子可以返回 false 以阻止该错误继续向上传播。renderTrackedonRenderTracked#renderTriggeredonRenderTriggered#

注意:因为 setup 是++围绕 beforeCreate 和 created++ 生命周期钩子运行的,所以不需要显式地定义它们。换句话说,在这些钩子中编写的任何代码都应该直接在 setup 函数中编写。

<script setup>onMounted(() => { console.log('Component is mounted!')})// ...</script>计算属性、侦听器<script setup>// 定义一个计算属性,计算年龄是否为18const ageIs18 = computed(() => { return age.value === 18})// 定义一个watch侦听器,监控count变化watch(count, (nV, oV) => { console.log(nV, oV)})</script>路由<!-- router.js -->import { createRouter, createWebHashHistory } from 'vue-router'const routes = [ { path: '/', redirect: '/home' // component: () => import('../pages/home.vue') // 组件懒加载 } ...]// 创建路由实例const router = createRouter({ history: createWebHashHistory(), // 使用 hash 模式 routes, // `routes: routes` 的缩写})export default router<!-- main.js -->import { createApp } from 'vue'import router from './router'...const app = createApp(App)app.use(router) // 挂载路由到Vue<!-- pages/home.vue --><script setup> import { useRouter } from 'vue-router' // useRouter()用于获取路由对象 const router = useRouter() router.push({ path: '/next' }) // useRoute()用于获取当前路由对象 const route = useRoute() const query = route.query</script>pinia

Vuex替代品,全局数据管理器

<!-- pinia/user.js -->import { defineStore } from 'pinia'import { ref, computed, reactive } from 'vue';// useStore 可以是 useUser、useCart 之类的任何东西// 第一个参数是应用程序中 store 的唯一 idexport const usePiniaStore = defineStore('user', () => { // vue3 setup编程模式,让结构更加扁平化 const _this = window.$this // state const userId = ref('111122') const userData = ref(null) // action const getUser = async () => { const res = await _this.$api.getId() userData.value = res.data } // getter const userName = computed(() => userData.value.id + ' ---- ') // 导出 return { userData, userName, getUser, userId }})<!-- pages/user.vue --><script setup> import { usePiniaStore } from '../pinia/user.js' // 使用pinia user module const useStore = usePiniaStore() // 解构state const { userData, userName, userId } = storeToRefs(useStore) // 直接调用pinia函数 useStore.getUser() // 直接赋值 userId.value = 'aaa' console.log(`userStore:`, userId.value, userData.value)</script>
本文链接地址:https://www.jiuchutong.com/zhishi/310881.html 转载请保留说明!

上一篇:mysql左外连接查询是什么(mysql左连接查询 效率)

下一篇:织梦dedecms如何更改plus文件夹名称(dede织梦怎么转成zblog)

  • 库存盘盈盘亏要调整吗
  • 退回代征手续费怎么做会计分录
  • 非居民劳务个税怎么计算
  • 土地政策补贴
  • 发票不附销货清单可以吗
  • 长期待摊费用的摊销方法
  • 医院计提坏账准备分录
  • 餐饮管理公司设哪些科目
  • 三证合一之后还有税务登记证吗
  • 逃避缴纳税款是税收法多少条
  • 税控服务费抵扣的文件
  • 业务招待费增值税是进项税吗
  • 税收理财跟税收筹划有什么区别?
  • 一般纳税人企业所得税税率2023
  • 工伤赔付是那个出钱呢
  • 产品研发费用属于固定成本吗
  • 善意取得虚开增值税专用发票追征期
  • 股份公司和有限公司工作哪个好一些
  • 使用的磁盘空间在哪
  • 收到政府补贴的装修款
  • 如何更改文件的创建时间
  • 先征后返的会计分录
  • 收到保险公司赔付的车辆维修费的会计分录
  • php curd
  • 一般纳税人出售旧设备的税率
  • php excute
  • 家具折旧费是什么意思
  • 公司承担责任的方式
  • 汽车销售行业的税负率是多少
  • swiper.js常用功能
  • php gzip压缩
  • PHP基于国秘s2m加解密的处理方式
  • 京东到家的物流模式
  • 计算机视觉算法
  • 收到股东投资款现金流量表入哪一项
  • 小企业会计准则和一般企业会计准则的区别
  • 长期股权投资哪些用成本法
  • 不免征个人所得税的是个人转让著作权所得
  • pandas columns排序
  • 个体户跨季领取发票流程
  • 简易征收预缴税款
  • 过路费一定是要公司的车辆吗
  • 购买仪器属于什么费用
  • 交易性金融资产公允价值变动计入
  • 申请电子发票需要什么条件
  • sqlserver去掉字符串内的指定字符
  • 出售专利技术收增值税吗
  • 基建和技改的区别
  • 开发票没有银行回单可以入帐吗?
  • 跨年多计提的工资如何处理
  • 员工借款怎么处理
  • 报名费无发票要补交吗
  • 丢失的发票怎么查询
  • 工伤误工费标准是按照社平工资来算的吗
  • 过路费抵扣进项税
  • 增值税相关的问题
  • 市政配套费减免政策
  • mac外接显示器不显示全部桌面
  • 如何隐藏windows激活水印
  • win10系统预览版
  • win10家庭版教程
  • linux用
  • jquery-file-upload 文件上传带进度条效果
  • 用kotlin开发android
  • javascript 作用域
  • 画廊作品
  • dos命令显示时间
  • jQuery中$.ajax()方法参数解析
  • jquery使用教程
  • javascript如何学
  • 面试java基础知识
  • javascript面向对象精要pdf
  • pythonfor else
  • python怎么定义
  • 郑州市惠济区税务局黄国选
  • 国家税务局吉林省税务局官网app
  • 深圳市税务局发短信是真的吗
  • 上海二手房个税退税政策
  • 写给税务局的表扬信
  • 车船税完税证明查询官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设