Vue3项目创建和使用

项目创建

        本文选用Vite搭建Vue3.x版本项目,详细内容可参考官方资料。

1.cmd执行命令:

npm init vite@latest

2.按照命令提示选用vue,运行完成项目就创建好了。

3.进入项目导入依赖:

npm i

4.运行项目:

npm run dev

项目创建完毕。

Vue3.x的使用

语法格式        

        使用上有多种语法格式,点击了解格式

钩子函数

import { onBeforeMount, onMounted, onBeforeUpdate, onUpdated, onBeforeUnmount, onUnmounted, onActivated, onDeactivated, onErrorCaptured } from 'vue'

export default {
  setup() {
    onBeforeMount(() => {
      // 挂载前
    })
    onMounted(() => {
      // 挂载后
    })
    onBeforeUpdate(() => {
      // 更新前
    })
    onUpdated(() => {
      // 更新后
    })
    onBeforeUnmount(() => {
      // 卸载前
    })
    onUnmounted(() => {
      // 卸载后
    })
    onActivated(() => {
      // 缓存路由激活
    })
    onDeactivated(() => {
      // 缓存路由卸载
    })
    onErrorCaptured(() => {
      // 错误捕获
    })
  }
}

响应式api

reactive     

        reactive() 函数接收对象返回响应式对象。

toRefs

        toRefs() 函数可以将reactive()创建出来的响应式对象,转换为普通对象。

<script>
	import { reactive, toRefs } from 'vue'
	export default {
		setup(props, context) {
		        let Main= reactive({
		             id: 0
		        });
		        return { ...toRefs(Main) };
		 }
	}
</script>

ref

        ref()函数接收一个参数值,返回一个响应式的数据对象。

<script>
	import { ref } from 'vue'
	export default {
		setup(props, context) {
		        let num = ref(100);
                console.log(num.value);//100
                num.value=200;
                console.log(num.value);//200
                return { num  };
		 }
	}
</script>

toRef

        toRef() 创建一个ref类型数据, 并和以前的数据关联。

computed

        computed() 用来计算属性。

<template>
  {{num}}
  {{double}}
  <button @click="add">add</button>
</template>

<script>
import { reactive, toRefs, computed} from 'vue'
export default {
  setup(props, context) {
    let Main=reactive({
      num:10,
      double : computed(() => Main.num * 2),
      add:()=>{
        Main.num++;
      }
    })
    return { ...toRefs(Main) };
  }
}
</script>

watch

        第一个参数监听的对象,第二个参数回调函数,第三个参数包含深度监听(监听复杂对象)和立即执行的配置。

<template>
  {{num}}
  <button @click="add">add</button>
  <button @click="stop">stop</button>
</template>

<script>
import { reactive, toRefs, watch} from 'vue'
export default {
  setup(props, context) {
    let Main=reactive({
      num:10,
      add:()=>{
        Main.num++;
      }
    })
    const unwatch = watch(
        ()=> Main.num,
        (newVal, oldVal) => {
          console.log(oldVal);
          console.log(newVal);
        },
        { deep: true, imediate: true }
    );
    const stop = () => {
      unwatch();
    };
    return { ...toRefs(Main) ,stop};

  }
}
</script>

provide(提供)与inject(注入)

        层级复杂时父组件向子孙组件提供方法等。

模板 Refs

<template>
  <div ref="divRef"></div>
  //还可以应用到组件上从而对子组件进行操作
</template>

<script>
import {nextTick, ref} from 'vue'
export default {
  setup(props, context) {
    const divRef=ref()
    nextTick(()=>{
      console.log(divRef.value.clientWidth)
    })
    return { divRef };
  }
}
</script>

组件通信

        可参考vue3不同语法格式对比 - 掘金

 1.在组件中使用setup函数

        父组件:

        通过ref可以获取子组件的方法和值,子组件需要将方法和值暴露出来(可以直接return出来,可以context.expose暴露出来)。

        子组件:

        通过props可以获取到父组件参数,context.emit()调用父组件方法。

2.在script标签上写setup <script setup>

        父组件:

        同样是使用ref与子组件通讯。

        子组件:

        defineProps获取参数, defineEmits调用方法, defineExpose暴露信息。

3.自定义组件上使用v-model

        Vue3.x版本做了一些变化,现在支持绑定多个了。

        详细可参考Vue3中的v-model与Vue2中的不同_是要开心的婷婷呀~的博客-CSDN博客

有问题的地方再修改。

参考博客:vue3初探---vue3新特性学习_guoang.的博客-CSDN博客_vue3

                  vue3不同语法格式对比 - 掘金

                  Vue3中的v-model与Vue2中的不同_是要开心的婷婷呀~的博客-CSDN博客

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值