Vue入门之v-on、v-model、v-if


天行健,君子以自强不息;地势坤,君子以厚德载物。


每个人都有惰性,但不断学习是好好生活的根本,共勉!


文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。


宫女如花满春殿,只今惟有鹧鸪飞。
——《越中览古》


文章目录

  • Vue入门之v-on、v-model、v-if
    • 1. `v-on`
      • 1.1 script setup
      • 1.2 template
      • 1.3 style scoped
      • 1.4 页面效果
    • 2. `v-model`
      • 2.1 script setup
      • 2.2 template
      • 2.3 style scoped
      • 2.4 页面效果
    • 3. `v-if`
      • 3.1 script setup
      • 3.2 template
      • 3.3 style scoped
      • 3.4 页面效果
    • 4. 代码示例
    • 5. 项目demo


Node.js的下载、安装和配置
node的下载、安装、配置和使用(node.js下载安装和配置、npm命令汇总、cnpm的使用)
Vue3入门之创建vue3的单页应用(vite+vue)
Vue入门第一篇(环境配置、脚手架安装、项目创建、项目运行访问、项目结构详解等)
Vue入门第二篇(基本语法、实例演示)
Vue专栏


Vue入门之v-on、v-model、v-if

文末附本文所有示例代码的下载地址以及基于vite构建vue3的项目demo地址

1. v-on

事件监听
使用v-on指令监听DOM事件,如v-on:click=“add”
v-on的简写语法使用@,如@click=“add”
触发的事件add需要在script setup标签中声明函数add()

1.1 script setup

script setup标签内的代码

// 3. 事件监听,使用v-on指令监听DOM事件,v-on也有一个简写语法省去v-on:,替换为@即可
const count2 = ref(0)
function increment(){count2.value++
}

1.2 template

template标签内的代码

  <!-- 3.  --><div><h2>3. 事件监听</h2><button id="btn-increment" v-on:click="increment">count2 is :{{ count2 }}</button></div><br>

1.3 style scoped

style scoped标签内的代码

/* 3.  */
#btn-increment{height: 50px;width: 400px;text-align: center;background-color: seagreen;font-size: 20px;
}

1.4 页面效果

控制台npm run dev启动项目,访问服务页面http://localhost:5173/
查看页面效果,点击绿色区域,即可实现数值累加效果
在这里插入图片描述
在这里插入图片描述

2. v-model

双向绑定
同时使用v-bind和v-on可以实现双向绑定
但为了更方便的使用,Vue中简化为v-model进行双向绑定的实现,此时可不用再写事件处理函数
如下进行了两种双向绑定的实现

2.1 script setup

script setup标签内的代码

// 4. 表单绑定
// 4.1 双向绑定 使用v-bind和v-on在表单的输入元素上创建双向绑定
const text = ref('')
function onInput(e){// v-on 处理函数会收到原生DOM事件作为其参数text.value = e.target.value
}// 4.2 表单绑定 简化双向绑定,使用v-model,会同步数据,不用使用事件绑定了,(除文本类型外其余输入也可使用该方法,如多选框、单选框、下拉框等)
const text2 = ref('')

2.2 template

template标签内的代码

  <!-- 4.1  --><div><h2>4.1 双向绑定</h2><input id="ipt-v1" :value="text" @input="onInput" placeholder="please type here something"><br><br><p>{{ text }}</p></div><!-- 4.2 --><div><h2>4.2 表单绑定</h2><input id="ipt-vmodel" v-model="text2" placeholder="type something here"><p>{{ text2 }}</p></div>

2.3 style scoped

style scoped标签内的代码

/* 4.1 */
#ipt-v1{height: 50px;width: 400px;text-align: center;background-color: tan;font-size: 30px;
}
/* 4.2  */
#ipt-vmodel{height: 50px;width: 400px;text-align: center;background-color: slategrey;font-size: 30px;
}

2.4 页面效果

控制台npm run dev启动项目,访问服务页面http://localhost:5173/
查看页面效果
在这里插入图片描述
在输入框中输入内容,查看绑定效果
在这里插入图片描述

3. v-if

条件渲染
通过v-if指令有条件的渲染元素
v-if条件值为真则渲染,值为假则从dom中移除
除了v-if还有v-else和v-else-if用来表示其他条件分支

3.1 script setup

script setup标签内的代码

// 5. 条件渲染 使用v-if有条件地渲染元素,当v-if属性的值对应的是真值Truthy时渲染,若为假值则会从dom中移出
// 除此之外,v-else、v-else-if可表示其他条件分支
const awesome = ref(true)
function toggle(){// if (awesome.value) {//   awesome.value = false// }else if(!awesome.value){//   awesome.value = true// }// 或者awesome.value = !awesome.value}

3.2 template

template标签内的代码

  <!-- 5.  --><div id="d-5"><h2>5. 条件渲染</h2><button id="btn-5" @click="toggle">Toggle</button><h1 id="h-5" v-if="awesome">Vue is awesome!</h1><h1 id="h-5" v-else>Oh no emo</h1></div>

3.3 style scoped

style scoped标签内的代码

/* 5.  */
#btn-5{height: 30px;width: 100px;text-align: center;border-radius: 20px;background-color: darkorange;font-size: 20px;
}
#h-5{height: 50px;width: 400px;text-align: center;border-radius: 20px;background-color: darkorange;font-size: 30px;
}

3.4 页面效果

控制台npm run dev启动项目,访问服务页面http://localhost:5173/
查看页面效果
在这里插入图片描述
点击Toggle按钮触发条件变更,可实现下方内容变换
在这里插入图片描述

4. 代码示例

以上示例的代码已打包上传到CSDN资源库,可自行下载获取示例代码
下载地址:Vue v-on v-model v-if 语法示例演示代码

5. 项目demo

本文示例代码都是基于vite构建的vue3项目编写,项目demo也已上传CSDN资源库
下载地址:Vue 基于vite构建vue3项目 以及基础语法演示
下载后如想正常运行项目,需先有node环境,可根据文章开始的链接进行下载安装node环境,以及配置node环境变量


感谢阅读,祝君暴富!


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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

高效实现GIS地图可视化,这款免费工具不可错过

GIS地图可视化怎么做&#xff1f;山海鲸可视化这款免费可视化工具帮你轻松搞定。从三维GIS地图可视化需求出发&#xff0c;山海鲸可视化提供了强大的GIS场景编辑功能&#xff0c;包括支持添加倾斜摄影和地形编辑。无论是复杂的地形调整还是细致的倾斜摄影添加&#xff0c;这款工…

【C++初阶】模板初阶

【C初阶】模板初阶 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;C&#x1f96d; &#x1f33c;文章目录&#x1f33c; 1. 泛型编程 2. 函数模板 2.1 函数模板的概念 2.2 函数模板格式 2.3 函数模板的原理 2.4 函数模板的实例化 2.…

【C++修炼之路 第四章】模板 初阶

引入&#xff1a; 我们平时需要调用这样的函数时&#xff0c;往往需要写不同类型的函数用于匹配操作不同类型变量 void Swap(int& a, int& b) {// ... } void Swap(double& a, double& b) {// ... } //......像上面代码中函数重载有一下几个不好的地方&#…

filebeat,kafka,clickhouse,ClickVisual搭建轻量级日志平台

springboot集成链路追踪 springboot版本 <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.6.3</version><relativePath/> <!-- lookup parent from…

Stateflow中的状态转换表

状态转换表是表达顺序模态逻辑的另一种方式。不要在Stateflow图表中以图形方式绘制状态和转换&#xff0c;而是使用状态转换表以表格格式表示模态逻辑。 使用状态转换表的好处包括&#xff1a; 易于对类列车状态机进行建模&#xff0c;其中模态逻辑涉及从一个状态到其邻居的转换…

处理uniapp刷新后,点击返回按钮跳转到登录页的问题

在使用uniapp的原生返回的按钮时&#xff0c;如果没有刷新会正常返回到对应的页面&#xff0c;如果刷新后会在当前页反复横跳&#xff0c;或者跳转到登录页。那个时候我第一个想法时&#xff1a;使用浏览器的history.back()方法。因为浏览器刷新后还是可以通过右上角的返回按钮…

SpringBoot限制请求访问次数

本篇文章的主要内容是SpringBoot怎么限制请求访问次数。 当我们的服务端程序部署到服务器上后&#xff0c;就要考虑很多关于安全的问题。总会有坏人来攻击你的服务&#xff0c;比如说会窃取你的数据或者给你的服务器上强度。关于给服务器上强度&#xff0c;往往就有高强度给服务…

​1:1公有云能力整体输出,腾讯云“七剑”下云端

【全球云观察 &#xff5c; 科技热点关注】 曾几何时&#xff0c;云计算技术的兴起&#xff0c;为千行万业的数字化创新带来了诸多新机遇&#xff0c;同时也催生了新产业新业态新模式&#xff0c;激发出高质量发展的科技新动能。很显然&#xff0c;如今的云创新已成为高质量发…

[React 进阶系列] useSyncExternalStore hook

[React 进阶系列] useSyncExternalStore hook 前情提要&#xff0c;包括 yup 的实现在这里&#xff1a;yup 基础使用以及 jest 测试 简单的提一下&#xff0c;需要实现的功能是&#xff1a; yup schema 需要访问外部的 storage外部的 storage 是可变的React 内部也需要访问同…

VulnHub:CK00

靶场搭建 靶机下载地址&#xff1a;CK: 00 ~ VulnHub 下载后&#xff0c;在vmware中打开靶机。 修改网络配置为NAT 处理器修改为2 启动靶机 靶机ip扫描不到的解决办法 靶机开机时一直按shift或者esc直到进入GRUB界面。 按e进入编辑模式&#xff0c;找到ro&#xff0c;修…

【devops】ttyd 一个web版本的shell工具 | web版本shell工具 | web shell

一、什么是 TTYD ttyd是在web端一个简单的服务器命令行工具 类似我们在云厂商上直接ssh链接我们的服务器输入指令一样 二、安装ttyd 1、macOS Install with Homebrew: brew install ttydInstall with MacPorts: sudo port install ttyd 2、linux Binary version (recommend…

Android10.0 锁屏分析-KeyguardPatternView图案锁分析

首先一起看看下面这张图&#xff1a; 通过前面锁屏加载流程可以知道在KeyguardSecurityContainer中使用getSecurityView()根据不同的securityMode inflate出来&#xff0c;并添加到界面上的。 我们知道&#xff0c;Pattern锁所使用的layout是 R.layout.keyguard_pattern_view&a…

Mysql基础与安装

一、数据库的概念和相关的语法和规范 1、数据库的概念 数据库&#xff1a;组织&#xff0c;存储&#xff0c;管理数据的仓库。 数据库的管理系统&#xff08;DBMS&#xff09;&#xff1a;实现对数据有效组织&#xff0c;管理和存取的系统软件。 数据库的种类&#xff1a; m…

QT 多线程 QThread

继承QThread的线程 继承 QThread 是创建线程的一个普通方法。其中创建的线程只有 run() 方法在线程里的。其他类内定义的方法都在主线程内。 通过上面的图我们可以看到&#xff0c;主线程内有很多方法在主线程内&#xff0c;但是子线程&#xff0c;只有 run() 方法是在子线…

Python | Leetcode Python题解之第236题二叉树的最近公共祖先

题目&#xff1a; 题解&#xff1a; # Definition for a binary tree node. # class TreeNode: # def __init__(self, x): # self.val x # self.left None # self.right Noneclass Solution:def lowestCommonAncestor(self, root: TreeNode, p…

实战篇(十一) : 拥抱交互的三维世界:利用 Processing 和 OpenGL 实现炫彩粒子系统

🌌 拥抱交互的三维世界:利用 Processing 和 OpenGL 实现炫彩粒子系统 在现代计算机图形学中,三维粒子系统是一个激动人心的领域。它不仅可以用来模拟自然现象,如烟雾、火焰和水流,还可以用来创造出令人叹为观止的视觉效果。在这篇文章中,我们将深入探讨如何使用 Proces…

第四届中国移动“梧桐杯”大数据创新大赛正式启动报名!

“梧桐杯”大赛是中国移动面向海内外高校青年学生打造的年度大数据创新赛事&#xff0c;以“竞逐数海&#xff0c;领航未来”为主题&#xff0c;携手政府、高校和行业企业通过比赛发掘高校优秀人才&#xff0c;孵化投资优秀项目。大赛设置“企业导师校内导师”双轨导师制&#…

Linux_线程的同步与互斥

目录 1、互斥相关概念 2、代码体现互斥重要性 3、互斥锁 3.1 初始化锁 3.2 申请、释放锁 3.3 加锁的思想 3.4 实现加锁 3.5 锁的原子性 4、线程安全 4.1 可重入函数 4.2 死锁 5、线程同步 5.1 条件变量初始化 5.2 条件变量等待队列 5.3 唤醒等待队列…

MySQL学习记录 —— 이십이 MySQL服务器文件系统(2)

文章目录 1、日志文件的整体简介2、一般、慢查询日志1、一般查询日志2、慢查询日志FILE格式TABLE格式 3、错误日志4、二进制日志5、日志维护 1、日志文件的整体简介 中继服务器的数据来源于集群中的主服务。每次做一些操作时&#xff0c;把操作保存到重做日志&#xff0c;这样崩…

JAVASE-医疗管理系统项目总结

文章目录 项目功能架构运行截图数据库设计设计模式应用单列设计模式JDBC模板模板设计模式策略模式工厂设计模式事务控制代理模式注解开发优化工厂模式 页面跳转ThreadLocal分页查询实现统计模块聊天 项目功能架构 传统的MVC架构&#xff0c;JavaFX桌面端项目&#xff0c;前端用…