学学vue-2

news/2024/9/17 15:17:54/ 标签: vue.js

1.7 指令修饰符

  • @keyup.enter:监听键盘回车事件,回车触发事件@keyup.enter代码

  • v-model修饰符:

    • v-model.trim:去首尾空格
    • v-model.number:变数字(如果是数字的话,转变为数字)
  • @事件名.stop:阻止冒泡现象,如果在大盒子中嵌套小盒子,点击小盒子之后,小盒子响应,之后大盒子也会相应,因为小盒子在大盒子所包含的区域当中,使用stop可以阻止这种冒泡行为 (可以通过在小盒子中添加e.stopPropagation()解决但是太长了)在小盒子的点击事件中直接写@click.stop即可达成效果

  • @事件名.prevent:阻止默认行为:比如写了一个超链接,把@click写成@click.prevent就不会跳转了上面三个修饰符

  • v-bind对于控件样式增强:

    • v-bind控制class。[v-bind class](#v-bind class)

      • 语法::class="对象/数组"

      • 对象键就是名,值是bool,如果值为true就有这个类,反之没有这个类
        数组中所有的类都会添加到盒子中,本质是一个class列表

      • 对象:<div class="box" :class="{ 类名1: 布尔值, 类名2: 布尔值 }"></div>
        数组:<div class="box" :class="[ 类名1, 类名2, 类名3]"></div>
        
      • 对象,适用场景:一个类名来回切换
        数组,适用场景:批量添加或者删除

    • v-bind行内样式(style)增强,操作style。[v-bind style](#v-bind style)

      • 语法::style="样式对象"(style中的json键值对需要将值引起来,否则报错)

      • 适用场景:某个属性动态设置

      • <div class="box" :style="{ css属性名1: css属性值, css属性名2: css属性值2}"></div>
        

@keyup.enter代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><div id="app"><h3>@keyup.enter → 监听回车事件</h3><input @keyup.enter='fn' v-model='username' type="text"></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><script>const app = new Vue({el: '#app',data: {username: ''},methods: {fn (e) {if (e.key === 'Enter') {console.log('键盘回车键触发', this.username)}}}})</script>
</body>
</html>

在这里插入图片描述

上面三个修饰符

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.outer{width: 100px;height: 100px;background-color: pink;position: relative;}.inner{width: 50px;height: 50px;background-color: cornflowerblue;position: absolute;top: 0;left: 0;}</style>
</head>
<body><div id="app"><h3>v-model修饰符 .trim .number</h3>姓名:<input v-model.trim="username" type="text"><br>年龄:<input v-model.number="age" type="text"><br><h3>@事件名.stop → 阻止冒泡</h3><div @click='outerFn' class='outer'><div @click.stop='innerFn' class='inner'>子块</div></div><h3>@事件名.prevent → 阻止默认行为</h3><a @click.prevent href="https://www.baidu.com">阻止默认行为</a></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><script>const app = new Vue({el: "#app",data: {username: '',userage: ''},methods: {outerFn(){alert("外部点击")},innerFn(e){// e.stopPropagation()alert("内部点击")}}})</script>
</body>
</html>

在这里插入图片描述

v-bind class

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>jd导航栏</title><style>/* 移除所有元素的默认外边距和内边距,以便更好地控制布局 */  * {  margin: 0;  padding: 0;  }  /* 设置无序列表的显示方式为Flex布局,并添加底部边框和内边距 */  ul {  display: flex; /* 使用Flexbox布局 */  border-bottom: 2px solid #e01222; /* 底部边框为2px宽的实线,颜色为#e01222 */  padding: 0 10px; /* 内边距设置为左右各10px,上下为0 */  }  /* 设置列表项的样式,包括宽度、高度、行高、移除列表符号以及文本居中对齐 */  li {  width: 100px; /* 每个列表项的宽度为100px */  height: 50px; /* 每个列表项的高度为50px */  line-height: 50px; /* 设置行高为50px,以实现垂直居中文本 */  list-style: none; /* 移除列表项前的默认项目符号 */  text-align: center; /* 文本在列表项中居中对齐 */  }  /* 设置列表项内链接的样式,包括显示方式、移除下划线、字体加粗和文本颜色 */  li a {  display: block; /* 将链接的显示方式设置为块级元素 */  text-decoration: none; /* 移除链接文本的下划线 */  font-weight: bold; /* 字体加粗 */  color: #333333; /* 文本颜色为深灰色#333333 */  }  /* 当链接具有active类时,改变其背景色和文本颜色 */  li a.active {  background-color: #e01222; /* 背景色变为#e01222(红色) */  color: #fff; /* 文本颜色变为白色 */  }</style>
</head>
<body><div id="app"><ul><li v-for="(item, index) in list" :key="item.id" @click="activeIndex = index"><a :class="{ active: index === activeIndex }" href="#">{{ item.name }}</a></li></ul></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script> <script>const app = new Vue({el: "#app",data: {activeIndex: 2,list: [{id: 1, name: '京东秒杀'},{id: 2, name: '每日特价'},{id: 3, name: '品类秒杀'}]}})</script>
</body>
</html>

在这里插入图片描述

v-bind style

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.progress-bar {  width: 100%; /* 进度条的总宽度 */  height: 20px; /* 与内部元素高度一致 */  border-radius: 10px; /* 圆角与内部元素一致 */  background-color: #e0e0e0; /* 外部容器的背景色,通常为灰色或浅色 */  overflow: hidden; /* 确保内部元素超出部分不可见 */  box-sizing: border-box; /* 使得padding和border包含在总宽度内 */  }  .inner {  width: 50%; /* 初始宽度,实际使用时可能通过JavaScript动态设置 */  height: 100%; /* 填满外部容器的高度 */  border-radius: 10px; /* 圆角与外部容器一致 */  text-align: right; /* 如果需要文本对齐,但通常进度条内部不放置文本 */  position: relative; /* 如果需要内部元素定位 */  background-color: #409eff; /* 进度条的颜色 */  background-size:  20px 20px; /* 这行通常用于背景图片,对于纯色背景不需要 */  transition: all 1s; /* 过渡效果(1s应为时间) */  }</style>
</head>
<body><div id="app"><!-- 外层盒子 灰色 --><div class="progress-bar"><!-- 内层盒子 蓝色 --><div class="inner" :style="{ width: percent + '%'}"><span>{{ percent }}%</span></div></div><button @click="percent = 25">25%</button><button @click="percent = 50">50%</button><button @click="percent = 75">75%</button><button @click="percent = 100">100%</button></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><script>const app = new Vue({el: '#app',data: {percent: 30}})</script>
</body>
</html>

在这里插入图片描述

1.8 v-model表单元素

常见的单元表格都可以使用v-model进行绑定关联→快速获取或者设置表单元素的值。他会根控件类型自动选取正确的元素类型

使用v-model绑定关联以后可以在data中快速取走上传的数据

常见表单元素:

表单元素自动关联类型
输入框input:textvalue
文本域textareavalue
复选框input:checkboxchecked
单选框input:radiochecked
下拉菜单selectvalue

radio的name和value(结合v-model使用这两个属性)(原生语法):

  • name属性实现给两个选项按钮分组,实现同时只有一个属性被选中
  • value实现给表单的value属性,用于提交后台的数据,配合name使用
  • name用于给用户看的是不会向后端传递什么数据的,使用value实现向后端传递数据
性别:<input v-model="gender" type="radio" name="gender" value="1"><input v-model="gender" type="radio" name="gender" value="2"><br><br>

原生语法:

  • option需要设置value值提交给后台
  • select的value值关联了选中的option的value值

在网页元素查找中因为没有显式指定元素,所以当前选中的元素会使用$0作为变量名来展示

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><div id="app"><h3>简历投递</h3>姓名:<input v-model="username" type="text"><br><br>是否单身:<input v-model="isSingle" type="checkbox"><br><br>性别:<input v-model="gender" type="radio" name="gender" value="1"><input v-model="gender" type="radio" name="gender" value="2"><br><br>所在城市:<select v-model="cityId"><option value="101">北京</option><option value="102">上海</option><option value="103">北京</option><option value="104">北京</option></select><br><br>自我描述:<textarea v-model="desc"></textarea><button>立即注册</button></div><script>const app = new Vue({el: "#app",data: {username: '',isSingle: false,gender: '1',cityId: '102',desc: ''}})</script>
</body>
</html>

1.9 计算属性

基于现有的数据,计算出来的新属性,依赖的数据变化,就会重新计算(vue是数据驱动的)

语法:

  • 在vue实例中声明computed配置项,一个计算属性对应一个函数
  • 使用起来和普通属性一样使用{{ 计算属性名 }}
computed: {计算属性名 () {基于现有数据逻辑return res}
}

计算属性就是将一段求值代码进行封装,在调用的时候,因为属性名是一个配置项调用不些括号,写括号会出现没有这个函数定义的错误,网页会直接崩溃

计算属性computed和method方法:

  • computed计算属性:封装一段数据的处理,求得一个结果。语法:

    • 写在computed配置项中
    • 作为属性,直接使用→this.计算属性{{ 计算属性 }}
  • method方法:给实例提供一个方法,调用以处理业务逻辑。语法:

    • 写在method配置项中
    • 作为方法,需要调用→this.方法名() {{ 方法() }} @事件名=“方法名”
  • 计算属性是有缓存的,这种缓存特性会将计算出的结果进行缓存,依赖项变化,会重新计算并在再次缓存

  • 可以说使用 computed 性能会更好,但是如果你不希望缓存,你可以使用 methods 属性。

计算属性的完整写法:

computed: {计算属性名: {get() {逻辑return res;}set(修改值) {逻辑return res;}}
}

参考文献

黑马程序员:https://www.bilibili.com/video/BV1HV4y1a7n4/
菜鸟教程:https://www.runoob.com/vue2/vue-tutorial.html


http://www.ppmy.cn/news/1524798.html

相关文章

k8s 高级调度

搞懂Kubernetes调度 K8S调度器Kube-schduler的主要作用是将新创建的Pod调度到集群中的合适节点上运行。kube-scheduler的调度算法非常灵活&#xff0c;可以根据不同的需求进行自定义配置&#xff0c;比如资源限制、亲和性和反亲和性等。 kube-scheduler的工作原理如下&#x…

基于大数据爬虫的高校网络舆情管控可视化大屏分析系统 8ov8c

目录 技术栈和环境说明具体实现截图预期达到的目标系统设计详细视频演示技术路线解决的思路性能/安全/负载方面可行性分析论证python-flask核心代码部分展示python-django核心代码部分展示研究方法感恩大学老师和同学源码获取 技术栈和环境说明 本系统以Python开发语言开发&am…

Python计算机视觉编程——第8章 图像内容分类

1 K邻近分类法 该算法将要分类的对象与训练集中已知类标记的所有对象进行对比&#xff0c;并由k近邻对指派到哪个类进行投票。该方法的弊端是&#xff1a;与k-means聚类算法一样&#xff0c;需要预先设定k值&#xff0c;k值得选择会影响分类得性能&#xff0c;而且这种方法要求…

AI教你学Python 第1天:Python简介与环境配置

大家好&#xff0c;我是凡人。 为啥要推出这个专栏呢&#xff0c;是因为大模型开发肯定离不开代码&#xff0c;那python可以说是现在流传最广&#xff0c;也非常吃香的语言&#xff0c;所以学Python没错的&#xff0c;所有文章内容全部来自于训练后的大模型生成。 第1天&#…

2024/9/6黑马头条跟学笔记(四)

D4内容介绍 阿里三方安全审核 分布式主键 异步调用 feign 熔断降级 1.自媒体文章自动审核 1.1审核流程 查文章——调接口文本审核——minio下载图片图片审核——审核通过保存文章——发布 草稿1&#xff0c;失败2&#xff0c;人工3&#xff0c;发布9 1.2接口获取 注册阿…

【C++二分查找】2517. 礼盒的最大甜蜜度

本文涉及的基础知识点 C二分查找 贪心&#xff08;决策包容性) LeetCode 2517. 礼盒的最大甜蜜度 给你一个正整数数组 price &#xff0c;其中 price[i] 表示第 i 类糖果的价格&#xff0c;另给你一个正整数 k 。 商店组合 k 类 不同 糖果打包成礼盒出售。礼盒的 甜蜜度 是礼…

Leetcode面试经典150题-141.环形链表

题目比较简单&#xff0c;重点是理解思想 解法都在代码里&#xff0c;不懂就留言或者私信 /*** Definition for singly-linked list.* class ListNode {* int val;* ListNode next;* ListNode(int x) {* val x;* next null;* }* }*/ public…

克雷格·费德里吉谈Apple Intelligence保密技术背后的挑战

苹果必须实现克雷格-费德里吉所说的突破&#xff0c;这样 Apple Intelligence公司才能在云中使用大型语言模型&#xff0c;同时还能保护用户隐私&#xff0c;苹果是这样做的。在"It’s Glowtime"活动中&#xff0c;苹果公司谈到了私有云计算作为保护用户隐私的方式。…

高级算法设计与分析 学习笔记5 红黑树

定义&#xff1a; 根节点必黑&#xff0c;红节点孩子必黑&#xff0c;叶子节点&#xff08;外部节点&#xff0c;null的那种&#xff09;也是黑&#xff0c;每条路的黑节点数量一致。 首先看各个节点的平衡值&#xff0c;从根节点开始算&#xff0c;哪个最后超过1就是从这里开始…

【Unity新闻】Unity将取消Runtime费用

兜兜转转又回来了&#xff0c;一大早就看到Unity发布新闻&#xff0c;将取消Runtime费用&#xff0c;但同时也将提高各级付费账号的年费。这是新任CEO Matt上任后的价格调整策略。 非常不错的一点是&#xff1a; 当 Unity 6 在今年晚些时候发布时&#xff0c;使用 Unity Pers…

问:有一种Java语法叫注解,一起来扒一扒~

在Java编程语言中&#xff0c;注解&#xff08;Annotation&#xff09;和元注解&#xff08;Meta-Annotation&#xff09;为开发者提供了丰富的机制来嵌入元数据&#xff0c;从而增强代码的可读性、可维护性&#xff0c;并允许编译器或运行时环境进行特定的处理。 一、注解&am…

大型语言模型:通过代码生成、调试和 CI/CD 集成改变软件开发的游戏规则

借助 AI&#xff0c;软件开发领域正在经历一个突破性阶段&#xff0c;不断集成最先进的大型语言模型&#xff0c;如 GPT-4 和 Claude Opus。这些模型超越了传统开发人员工具的作用&#xff0c;直接帮助开发人员将口头指令转换为跨各种编程语言的可执行代码&#xff0c;从而加快…

深度学习的零碎知识点

显卡内存 什么是显卡内存 简单来说就是&#xff0c;Windows 会在物理显存/「专用 GPU 内存」不够用或只有集成显卡的情况下&#xff0c;将物理内存 RAM 当作 GPU 的虚拟显存/「共享 GPU 内存」来使用。 什么是 Windows「共享 GPU 内存」&#xff0c;它与 VRAM 有什么不同 (s…

【学习笔记】SSL密码套件之哈希

本篇将介绍TLS/SSL密码套件中常用的哈希算法&#xff0c;包括Poly1305、SHA384、SHA256、SHA、MD5 以上的哈希算法将作为 MAC 使用 MAC - Message Authentication Code 为批量数据提供了完整性&#xff08;Integrity&#xff09;以及真实性&#xff08;Authentication&#xf…

yolo学习 (一) 安装yolov8及训练

随便搞个python环境&#xff0c;直接装或者anaconda都行&#xff0c;python版本最低3.8以上 一、安装yolov8 &#xff08;cpu版本&#xff09; pip install ultralytics yolov8安装版本比较省事&#xff0c;不过这里默认装的是CPU版本 import torch print(torch.__version_…

前端 + 接口请求实现 vue 动态路由

前端 接口请求实现 vue 动态路由 在 Vue 应用中&#xff0c;通过前端结合后端接口请求来实现动态路由是一种常见且有效的权限控制方案。这种方法允许前端根据用户的角色和权限&#xff0c;动态生成和加载路由&#xff0c;而不是在应用启动时就固定所有的路由配置。 实现原理…

【springboot】整合spring security 和 JWT

目录 1. 整合spring security 1. 导入依赖 2. 配置类 3. 实体类实现UserDetails接口 4. 业务逻辑实现类实现UserDetailsService接口 5. 控制类实现登录功能 6. 测试登录功能 2. 分析源码 1. UsernamePasswordAuthenticationToken 2. A…

windows JOB作业类的处理

windows JOB作业类的处理 windows JOB作业类的处理 文章目录 windows JOB作业类的处理 # windows JOB作业类的处理 /* moduel Job.h Notices: */#pragma once #include <malloc.h> //for _alloca; class CJob { private:HANDLE m_hJob; public:CJob(HANDLE hJob NULL);…

论文翻译:USENIX-2021 Extracting Training Data from Large Language Models

Extracting Training Data from Large Language Models 从大型语言模型中提取训练数据 https://www.usenix.org/system/files/sec21-carlini-extracting.pdf 文章目录 从大型语言模型中提取训练数据摘要1 引言 摘要 现在&#xff0c;发布在私有数据集上训练的大型&#xff…

828华为云征文|基于华为云Flexus云服务器X部署Minio服务

文章目录 ❀前言❀Minio简介❀部署环境准备❀yum环境配置❀安装docker❀获取镜像❀创建挂载目录❀启动容器❀查看容器状态❀安全组开放❀浏览器访问❀总结 ❀前言 大家好&#xff0c;我是早九晚十二。 近期华为云推出了最新的华为云Flexus云服务器X&#xff0c;这款云主机在算…