Vue 基础语法

【1】模板语法

(1)差值表达式

  • {{}}是 Vue.js 中的文本插值表达式。

    • 它用于在模板中输出数据或表达式的值。当数据或表达式的值发生变化时,插值表达式会自动更新。
  • 补充:三目运算符

    • 它的基本语法是 Condition ? A : B,意思是当 Condition 为真时,执行 A,否则执行 B

image-20240424185144908

<body>
<div id="app"><li>字符串:{{name}}</li><li>数值:{{age}}</li><li>数组:{{list1}}</li><li>对象:{{obj1}}</li><li>字符串:{{link1}}</li><li>运算:{{1 + 2 +3 + 4}}</li><li>三目运算符:{{1 > 2 ? 'Y' : 'N'}}</li>
</div>
</body><script>var vm = new Vue({el: "#app",data: {name: 'bruce',age: 18,list1: [1, 2, 3, 4],   // 数组obj1: {name: 'Darker', age: 19},link1: '<a href="https://www.baidu.com">百度一下 你就知道</a>'}})
</script>

【2】文本指令

(1)v-html和v-text

  • v-html

    • v-html 指令用于更新元素的 innerHTML

    • 这个指令可以输出真正的 HTML 内容,而不仅仅是纯文本。

      • 如果你尝试用双花括号 {{ }} 插入 HTML,它将被转义并显示为纯文本。
      • 但是使用 v-html 可以直接插入 HTML 内容。
    • 使用 v-html可能会带来 XSS 攻击的风险

  • v-text

    • v-text 指令用于更新元素的文本内容。
    • 它基本上与双花括号 {{ }} 的功能相同,但 v-text 不会在元素上创建额外的文本节点。
    • 如果元素已经包含文本内容,v-text 会替换这些文本内容。

image-20240424172743630

<body>
<div id="app"><div v-html="htmlContent"></div><div>{{htmlContent}}</div><hr><div v-text="textContent"></div><div>{{textContent}}</div>
</div>
</body><script>var vm = new Vue({el: "#app",data: {htmlContent: '<span style="color: red">标签:红色文字</span>',textContent: '纯文本内容'}})
</script>

(2)v-if和v-show

  • v-if
    • v-if 指令用于条件性地渲染一个元素
    • 只有当其表达式的值为真值时,才会渲染元素及其内容。如果表达式的值为假值,则元素及其内容不会被渲染到 DOM 中。
    • 这意味着每次 v-if 的条件改变时,都会进行条件块的销毁或重建,这是一个“真正”的条件渲染。
  • v-show
    • v-show 指令与 v-if 类似,也是用于根据条件来显示或隐藏元素。但是,无论 v-show 的表达式值为真值还是假值,元素始终会被渲染到 DOM 中。
    • v-show 只是简单地通过切换元素的 CSS 属性 display控制其可见性
image-20240424184439938
<div id="app"><div v-if="true">v-if渲染</div><div v-if="false">v-if不渲染</div><hr><div v-show="true">v-show渲染</div><div v-show="false">v-show不渲染</div>
</div>

【3】事件指令

(1)v-on+click

  • Vue 提供了许多事件指令,用于处理 DOM 事件这些指令以 v-on 或其简写 @ 开头,后面跟上要监听的事件名称。
  • 当在 Vue 组件的模板中使用这些指令时,它们可以绑定到组件的方法或表达式上,以便在特定事件发生时执行相应的操作。
<body>
<div id="app"><span v-text="info" v-on:click="handleClick" style="background-color: coral; font-size: 30px"></span><br><img v-show="pTag" src="https://pic.netbian.com/uploads/allimg/240420/003439-1713544479de41.jpg" alt=""height="300px" width="500px">
</div>
</body><script>var vm = new Vue({el: "#app",data: {pTag: true,info: "关闭图片",},methods: {handleClick: function () {this.pTag = !this.pTagconsole.log(this.pTag)if (this.pTag) {this.info = '关闭图片'} else {this.info = '显示图片'}},}})
</script>

image-20240425161000332

(2)参数问题

  • 示例:v-on:click@click后面跟着自定义事件,正常传参正常执行,这里说一下不正常的情况
    • 函数有参,前端方法不传递,不加括号 ----> 函数将拿到当前操作事件
    • 函数有参,前端方法不传参数,加括号 ----> 函数将拿不到任何值
    • 函数有参,前端方法多传参数(‘1’, ‘2’) ----> 函数将拿到接收个数的参数
    • 函数有参,前端方法手动传递($event) ----> 函数将拿到当前操作事件

image-20240425162546478

<body>
<div id="app"><h2 v-text="info1" @click="handleClick">dada</h2><h2 v-text="info2" @click="handleClick()">dada</h2><h2 v-text="info3" @click="handleClick('1', '2')">dada</h2><h2 v-text="info4" @click="handleClick($event)">dada</h2>
</div>
</body><script>var vm = new Vue({el: "#app",data: {info1: "函数有参,前端方法不传递,不加括号",info2: "函数有参,前端方法不传参数,加括号",info3: "函数有参,前端方法多传参数('1', '2')",info4: "函数有参,前端方法手动传递($event)",},methods: {handleClick: function (e) {console.log(e)},}})
</script>

【4】属性指令v-bind

(1)基础属性src等

  • v-bind是 vue 中的一个核心指令,用于响应式地更新 HTML 属性。可以简写为:,简单来说就是将属性变为了变量。
  • 其基本功能是将表达式(通常是 JavaScript 表达式)的结果绑定到一个元素的属性上。这样,当 Vue 实例中的数据发生变化时,绑定的属性也会自动更新。

image-20240425163859157

<body>
<div id="app"><button v-text="info" @click="handleChange" style="font-size: 30px"></button><img :src="imageList[index]" style="display: block; width: 500px; height: 300px;">
</div>
</body><script>var vm = new Vue({el: "#app",data: {info: "切换图片",index: 0,imageList: ["https://pic.netbian.com/uploads/allimg/240424/003411-1713890051411d.jpg", "https://pic.netbian.com/uploads/allimg/240424/001415-171388885570eb.jpg", "https://pic.netbian.com/uploads/allimg/240422/005357-17137184373f8b.jpg"]},methods: {handleChange: function () {this.index = (this.index + 1) % this.imageList.length},}})
</script>

(2)style和class属性

  • class属性语法::class='字符串、js数组、js对象'
    • 字符串格式:需要手动拼接样式,不推荐
      • classStr: "div1"
      • this.classStr = this.classStr + ' div2'
    • js数组格式:需要对列表进行添加push操作删除pop操作推荐
      • classList: ["div1"]
      • this.classList.push("div2")
    • js对象格式:通过键值对修改样式,判断键对应值的Bool值,不推荐
      • classObj: {"div1": true, "div2": false}
      • this.classObj.div2 = true

image-20240425172737072

<style>.div1 {background-color: #44f1aa;height: 200px;width: 200px;}.div2 {border-radius: 50%;}
</style><body>
<div id="app"><button v-text="info" @click="handleChange"></button><div :class="classObj"></div>
</div>
</body><script>var vm = new Vue({el: "#app",data: {info: "样式切换",// 字符串形式classStr: "div1",// js数组形式classList: ["div1"],// js对象形式classObj: {"div1": true, "div2": false}},methods: {handleChange: function () {// 字符串形式操作// this.styleStr = this.styleStr + ' div2'// js数组形式操作// this.styleList.push("div2")// js对象形式操作this.classObj.div2 = true},}})
</script>
  • style属性语法::style='字符串、js数组、js对象'

    • 字符串格式:需要手动拼接样式,不推荐

      • styleStr: "background-color: #44f1aa; height: 200px; width: 200px;"
      • this.styleStr = this.styleStr + ' border-radius: 50%;'
    • js数组格式:需要对列表进行添加push操作删除pop操作,不推荐

      • styleList: [{backgroundColor: "#44f1aa"}, {height: "200px"}, {width: "200px"}]

      • this.styleList.push({borderRadius: "50%"})

    • js对象格式:通过键值对修改样式,判断键对应值的Bool值,推荐

      • styleObj: {backgroundColor: "#44f1aa", height: "200px", width: "200px"}
      • this.styleObj.borderRadius = "50%"
  • 但是有时候会出现这种情况:页面中的值修改成功了,但是样式却没有改变,这是因为ViewModel的并没有识别到属性的变化

image-20240426105852869

  • 这个时候需要使用Vue的语法set
    • Vue.set 的语法用于向响应式对象添加一个属性,并确保这个新属性也是响应式的。
    • Vue.set(target, propertyName/index, value)
      • target: 目标对象或数组。
      • propertyName/index: 要添加或修改的属性名(对于对象)或索引(对于数组)。
      • value: 要设置的新值。
<body>
<div id="app"><button v-text="info" @click="handleChange"></button><div :style="styleObj"></div>
</div>
</body><script>var vm = new Vue({el: "#app",data: {info: "样式切换",// 字符串形式styleStr: "background-color: #44f1aa; height: 200px; width: 200px;",// js数组形式styleList: [{backgroundColor: "#44f1aa"}, {height: "200px"}, {width: "200px"}],// js对象形式styleObj: {backgroundColor: "#44f1aa", height: "200px", width: "200px"}},methods: {handleChange: function () {// 字符串形式操作this.styleStr = this.styleStr + ' border-radius: 50%;'// js数组形式操作this.styleList.push({borderRadius: "50%"})// js对象形式操作// this.styleObj.borderRadius = "50%"Vue.set(this.styleObj, "borderRadius", "50%")},}})
</script>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32CubeMX打开中文乱码

在STM32CubeMX生成的文件中&#xff0c;用Keil5打开中&#xff0c;在其中写入中文注释之后&#xff0c;再次用STM32CubeMX打开生成之后&#xff0c;部分中文就会出现乱码问题&#xff0c;在Keil5中的编码是使用utf-8的编码格式&#xff0c;而在windows系统下&#xff0c;STM32C…

一起了解开源自定义表单的优势表现

随着社会的进步和科技的发展&#xff0c;越来越多的中小企业希望采用更为先进的软件平台&#xff0c;助力企业实现高效率的流程化管理。低代码技术平台、开源自定义表单已经慢慢走入大众视野&#xff0c;成为一款灵活、高效的数字化转型工具。流辰信息专注于低代码技术平台的研…

鸿蒙内核源码分析(原子操作篇) | 谁在为原子操作保驾护航

基本概念 在支持多任务的操作系统中&#xff0c;修改一块内存区域的数据需要“读取-修改-写入”三个步骤。然而同一内存区域的数据可能同时被多个任务访问&#xff0c;如果在修改数据的过程中被其他任务打断&#xff0c;就会造成该操作的执行结果无法预知。 使用开关中断的方…

更适合宝妈和上班族的兼职,每天2小时收入250+的微头条项目

许多人通过撰写微头条赚取收入&#xff0c;但这通常需要自己寻找素材&#xff0c;然后逐字逐句地进行改编创作&#xff0c;整个过程既繁琐又低效。 然而&#xff0c;如今全球范围内的AI工具正如雨后春笋般涌现。百度推出了文心一言&#xff0c;阿里巴巴推出了AI工具通义千问&a…

【必看】ESP32-C3 IDF+VsCode 开发环境搭建(ubuntu 22.04)

详细可阅读官方文档&#x1f603;&#xff08;release/v4.4&#xff09;&#xff1a;点此进入 一、 安装准备&#x1f6e0;︎ 1.1 工具链安装 编译 ESP-IDF 需要以下软件包 sudo apt-get install git wget flex bison gperf python3 python3-pip python3-setuptools cmake n…

【信息系统项目管理师知识点速记】质量管理:控制质量

控制质量是为了评估绩效,确保项目输出完整、正确且满足客户期望,而监督和记录质量管理活动执行结果的过程。控制质量过程需要在整个项目期间开展,其目的是测量产品或服务的完整性、合规性和适用性,以确保项目达到主要干系人的质量要求。 12.5.1 输入 项目管理计划 质量管理…

JavaSE_抽象类(抽象类概念、语法、、特性、作用)

前言 在上一节中&#xff0c;我们讲解了JAVA中的继承&#xff0c;在本节讲解java中抽象类与接口&#xff0c;这个在程序设计中是非常重要的。 一、什么是抽象类 1.1 抽象类概念 基本概念&#xff1a; 在面向对象的概念中&#xff0c;所有的对象都是通过类来描绘的&#xff0…

动态规划——背包问题(01,完全,多重)

一、01背包问题 1.题目描述 有 N 件物品和一个容量是 V 的背包。每件物品只能使用一次。第 i 件物品的体积是 vi&#xff0c;价值是 wi。 求解将哪些物品装入背包&#xff0c;可使这些物品的总体积不超过背包容量&#xff0c;且总价值最大。输出最大价值。 01背包问题特点&…

客户管理软件排行榜:对比18款CRM

本文将对比18个客户管理软件&#xff1a;纷享销客、Zoho CRM、Salesforce、HubSpot CRM、Pipedrive、Freshsales、Microsoft Dynamics 365 CRM、Insightly CRM、Nimble CRM、Apptivo CRM、SugarCRM、白码CRM、简信CRM、销帮帮CRM、Teamface企典CRM、神州云动CRM、悟空CRM、八百…

由于找不到msvcp120.dll,无法继续执行代码的5种解决方法

在操作计算机的过程中&#xff0c;您或许会遇到这样一种情形&#xff1a;当试图启动某个软件应用程序时&#xff0c;系统突然弹出一个错误提示框&#xff0c;明确指出“找不到msvcp120.dll”&#xff0c;它会导致程序无法正常启动或运行。为了解决这个问题&#xff0c;我总结了…

详细分析Java中的@Service注解

目录 1. 基本知识2. Demo2.1 传统形式2.2 注解形式 3. 总结 1. 基本知识 Service 是 Spring Framework 中的一个注解&#xff0c;用于标识一个类为服务层组件 服务层&#xff08;Service Layer&#xff09;&#xff1a; 服务层是应用程序的一个层次结构&#xff0c;位于控制层…

OpenNJet:云原生技术中的创新者与实践者

目录 引言OpenNJet介绍OpenNJet优势1. 性能无损动态配置2. 灵活的CoPilot框架3. 支持HTTP/34. 支持国密5. 企业级应用6. 高效安全 OpenNJet 编译与安装环境准备编译环境配置配置yum源yum 安装软件包创建符号连接修改 ld.so.conf 配置 编译代码 部署 WEB SERVER配置OpenNJet部署…

深入探索JDK:Java开发工具包的奥秘

深入探索JDK&#xff1a;Java开发工具包的奥秘 随着信息技术的飞速发展&#xff0c;Java作为一种广泛使用的编程语言&#xff0c;在各个领域都发挥着重要作用。而JDK&#xff08;Java Development Kit&#xff0c;Java开发工具包&#xff09;作为Java编程的基础&#xff0c;其…

k8s的架构组成

一 k8s的概述 1.1 概述 k8s是一个轻便的和可扩展的开源平台&#xff0c;用于管理容器化应用和服务&#xff0c;通过k8s能够进行应用的自动化部署和扩缩容。 k8s可以创建多个容器&#xff0c;每个容器运行一个应用实例&#xff0c;然后通过内置的负载均衡策略&#xff0c;实现…

Docker安装gitlab后连接内置pgsql修改用户信息

Docker安装gitlab后连接内置pgsql修改用户信息 进入gitlab容器 docker exec -it gitlab /bin/bash 进入postgresql su - gitlab-psql 连接pgsql psql -h /var/opt/gitlab/postgresql -d gitlabhq_production 命令行直接执行SQL语句 psql -h /var/opt/gitlab/postgresql…

HCIP-Datacom-ARST必选题库_BGP【道题】

1.关于summary automatic命令和BGP聚合的描述,错误的是? 该命令用于实现自动聚合,其优先级高于手动聚合 配置该命令后,BGP将按自然网段聚合路由 该命令用来使能对本地引入的路由进行自动聚合 配置该命令后,BGP只向对等体发送聚合后的路由 1.关于summary automatic命令和BGP聚…

Vue入门到关门之Vue3项目创建

一、vue3介绍 1、为什么要学习vue3&#xff1f; vue3的变化&#xff1a; 首先vue3完全兼容vue2&#xff0c;但是vue3不建议用vue2的写法&#xff1b;其次&#xff0c;vue3拥抱TypeScript&#xff0c;之前vue2使用的JavaScript&#xff0c;ts完全兼容js 最后之前学的vue2 是…

面试经典150题——找出字符串中第一个匹配项的下标

面试经典150题 day23 题目来源我的题解方法一 库函数方法二 自定义indexOf函数方法三 KMP算法 题目来源 力扣每日一题&#xff1b;题序&#xff1a;28 我的题解 方法一 库函数 直接使用indexOf函数。 时间复杂度&#xff1a;O(n) 空间复杂度&#xff1a;O(1) public int str…

(数据分析方法)长期趋势分析

目录 一、定义 二、目的 三、方法 1、移动平均法 (1)、简单移动平均法 (2)、加权移动平均法 (3)、指数平滑法 2、最小二乘法 3、线性回归 1、数据预处理 2、观察数据分布建立假设模型 3、定义损失函数 4、批量梯度下降 5、优化 4、LSTM 时序分析 5、特征工程 一…

vue3中的reactive和ref

&#x1f30f;总结&#xff1a;reactive 适用于创建复杂的响应式对象&#xff0c;而 ref 则适用于创建简单的响应式值。 reactive 和 ref 是 Vue 3 Composition API 中用于创建响应式数据的两种主要方式&#xff0c;它们的作用如下&#xff1a; 响应式数据管理&#xff1a; rea…