vue3语法

## vue3语法使用和api

### setup ref reactive

setup在beforeCreate,created前,现在用它来取代这两个生命周期函数。

用ref和reactive包裹的数据是具有响应式的。ref一般包裹的简单数据类型,reactive一般包裹的是复杂数据类型。

<template>

  <div class="home">{{name1}}-----{{name2}}</div>

</template>

<script setup>

import {ref,reactive,onMounted}from 'vue'

let name1='哈哈哈'//不具有响应式

let name2=ref('wow')//具有响应式

onMounted(()=>{//进页面就执行的

    console.log('hahahhaha');

    name2.value='呵呵呵'

})

</script>

### computed

在v3中,把computed变成了组合式API,使用时需要引入.

和vue2中一样,计算属性根据你依赖的数据变更,如果依赖的数据没有变更,则不会重新计算。通常,我们并不建议去修改计算属性计算出来的值(fullName).

<template>

 <p>名字是:{{fullname}}</p>

</template>

<script setup>

import {computed} from 'vue'

let names=reactive({

    a:'阿',

    b:'未'

})

let fullname=computed(()=>{

    return names.a + names.b

})

</script>

### watch

监听单个响应式数据时,当num发生变化的时候,会执行watch中的函数

<template>

 <p>{{num}}</p><button @click="add()">add</button>

</template>

<script setup>

import {ref} from 'vue'

let num =ref('0')

watch(num,(newValue,oldValue)=>{

    console.log(`'当前数字增加了',${newValue},${oldValue}`);

})

function add(){

    num.value++

}

</script>

监听reactive:

<template>

 <p>名字是:{{fullname}}</p><button @click="change()">change</button>

</template>

<script setup>

import {reactive} from 'vue'

let names=reactive({

    a:'阿',

    b:'未'

})

watch(names.a,(newValue,oldValue)=>{

    console.log(`'当前',${newValue},${oldValue}`);

})

function change(){

    names.a='话'

}

</script>

监听多个属性:

watch([()=>names.a,()=>names.b],(newValue,oldValue)=>{

  console.log('names改变了',newValue,oldValue)

})

深度监听:

<script setup>

let names=reactive({

      familyName: '鳌',

      age:23,

      job:{

        salary:10

      }

    })

//第一种

watch(()=> names.job.salary,(newValue,oldValue)=>{

  console.log('names改变了',newValue,oldValue)

})

//第二种

watch(()=> names.job,(newValue,oldValue)=>{

  console.log('names改变了',newValue,oldValue)

},{deep:true})

</script>

### 通过ref获取并操作dom元素

<template>

<input  ref="uploadFile" />

</template>

<script setup>

const uploadFile = ref(null);

//而后在页面已经渲染之后:

 console.log('---', uploadFile.value);

uploadFile.value.click();

</script>


 

对于vue3语法高亮混乱的问题,你可以尝试以下解决方法。首先,确保你已经安装了Vetur插件。然后,按照以下步骤进行设置。打开VSCode,点击左下角的齿轮图标,进入设置。在搜索框中搜索"setting",点击"字体",然后再setting.json文件中进行编辑。在文件中添加如下代码: ``` "files.associations": { "*.vue": "html" } ``` 保存文件后,重启VSCode,你应该能够看到vue文件的语法高亮效果恢复正常了。如果问题仍然存在,你可以尝试恢复VSCode的初始设置。你可以找到VSCode的配置文件,并注释掉其中的所有内容,然后在文件中添加以下代码: ``` { "editor.fontSize": 16 } ``` 保存文件后,重启VSCode,这样应该能够解决语法高亮混乱的问题。希望对你有所帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [vscode开发vue项目 代码高亮/语法提示 失效解决方法](https://blog.csdn.net/qq_39167720/article/details/125936962)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [vscode之.Vue文件高光显示及报错问题](https://blog.csdn.net/z914020826/article/details/126941441)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值