VUE3的学习和使用 vue语句
1.v-model和:value的区别
:value绑定只是v-bind单向的数据绑定,组件内部修改了对应的值,需要添加change方法改变data;
v-model的绑定是双向的,组件内部的值变化了,也会同步到页面的data中。
<Input v-model:value="userName" /> <Input :value="userName" @change="(e) => {changeValue('userName',e.target.value)}" />
两种写法的效果是一样的
:value后可以接js表达式,v-model只能接数值,否则报错。
2.v-if和v-show,:is的区别
v-if dom元素不渲染
v-show 有dom节点,但是该元素不显示,css样式display:none
:is 多用于动态切换组件,如:
<div> // flag 为真显示组件一,否则显示组件二 <Component :is="flag ? ComponentOne : ComponentTwo" /> </div>
3.v-if和v-for不能同时使用
v-for比v-if优先级更高,所以先运行循环,在每条循环中都要进行一次判断。
解决办法,在v-for外面嵌套一层<template>,如
// 错误写法 <li v-for="item in list" :key="index" v-if="showFlag"> {{item}} </li> // 优化后 <template v-if="showFlag"> <li v-for="item in list" key="index"> {{item}} </li> </template>
4.:class动态命名类名
// 动态命名 连接符或者传入多个参数 <div :class="`btn${isPlay ? 'btn-play' : ''}`" /> <div :class="['btn', 'btn-bg', isPlay ? 'btn-play' : '']"/>
5.route和router的区别
router可以操作路由,如push方法,
route包含当前路由的各种参数信息,如path等。
import { useRoute, useRouter, } from 'vue-router'; const route = useRoute(); const router = useRouter(); // 获取当前路径 const currentPath = computed(() => route.path); // 跳转到当前路由 router.push(currentPath);
6.h()和createVNode()
h()函数和createVNode()函数都是创建dom节点
h(标签, {属性},内容)
h(标签, {属性},[可以继续嵌套h()])
createVNode(标签, {属性},内容)
createVNode(标签, {属性},[可以继续嵌套createVNode()])
......
(持续待更新)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下