vue2,3:v-model的语法糖
Vue2的v-model 语法糖
**1. **v-model 的作用
v-model 是 Vue 中用于实现双向数据绑定的指令,主要用于表单元素(如 、、)和自定义组件。它简化了数据与视图之间的同步,使得开发者可以方便地处理用户输入。
**2. **v-model 的语法糖
v-model 实际上是 Vue 提供的一种语法糖,它是对 :value 和 @input(或类似的绑定/事件对)的封装。
- 对于表单元素**:**
-
v-model=“data” 等价于:
html<input :value="data" @input="data = $event.target.value" />
- :value 绑定数据到输入框的值。
- @input 监听输入事件,并将输入框的值($event.target.value)更新到绑定的数据 data。
-
- 对于自定义组件**:**
-
v-model 默认绑定组件的 value 属性(props)和 input 事件:
html<custom-component v-model="data"></custom-component>
等价于:
html<custom-component :value="data" @input="data = $event"></custom-component>
- 组件内部通过 this.$emit(‘input’, newValue) 触发 input 事件,更新父组件的数据。
-
**3. **v-model 的原理
v-model 的核心是 Vue 的响应式系统和事件机制的结合:
- 响应式数据绑定:
- 当使用 v-model 时,Vue 会将绑定的数据(如 data)设置为响应式。
- 当数据发生变化时,Vue 通过响应式系统更新视图(例如,表单元素的 value)。
- 事件监听与数据更新:
- Vue 监听表单元素的 input 事件(或其他相关事件,如 change)。
- 当用户输入时,触发事件,Vue 将事件的值更新到绑定的响应式数据。
- 数据更新后,响应式系统通知视图重新渲染,保持数据和视图同步。
- 组件中的 v-model:
-
在自定义组件中,v-model 依赖于组件的 value 属性和 input 事件。
-
组件内部通过 $emit(‘input’, newValue) 通知父组件更新数据。
-
如果需要自定义 v-model 的属性名和事件名,可以通过组件的 model 选项实现:
javascriptVue.component('custom-input', {model: {prop: 'customValue', // 自定义 prop 名event: 'customEvent' // 自定义事件名},props: ['customValue'],template: `<input:value="customValue"@input="$emit('customEvent', $event.target.value)">` });
使用时:
html<custom-input v-model="data"></custom-input>
此时,v-model 会绑定 customValue 属性和监听 customEvent 事件。
-
**4. **不同表单元素的 v-model 行为
Vue 会根据表单元素的类型调整 v-model 使用的属性和事件:
- :绑定 value 属性,监听 input 事件。
- 或 :绑定 checked 属性,监听 change 事件。
- :绑定 value 属性,监听 change 事件。
**5. **注意事项
- 修饰符:
-
v-model 支持修饰符,如 .lazy(在 change 事件而非 input 事件触发)、.number(将输入转为数字)、.trim(去除首尾空格)。
-
示例:
html<input v-model.lazy.number.trim="data" />
-
- 性能:
- v-model 的双向绑定依赖响应式系统,频繁更新可能影响性能,需谨慎使用。
- 自定义组件的限制:
- 默认情况下,v-model 假设组件有 value 属性和 input 事件。如果组件逻辑复杂,建议显式使用 :value 和 @input。
**6. **总结
- v-model 是 :value 和 @input(或类似绑定/事件对)的语法糖,简化了双向数据绑定的实现。
- 其原理基于 Vue 的响应式系统和事件机制,通过监听用户输入事件更新数据,并通过响应式系统同步视图。
- 在自定义组件中,v-model 可以通过 model 选项自定义属性和事件名,灵活适配不同场景。
vue3的v-model 语法糖
Vue 3 中 v-model 的使用
在 Vue 3 中,v-model 依然是实现双向数据绑定的核心指令,主要用于表单元素和自定义组件。相比 Vue 2,Vue 3 的 v-model 引入了一些改进,尤其是在自定义组件的使用上更加灵活,支持多重绑定和自定义修饰符。以下是 Vue 3 中 v-model 的使用详解。
**1. **v-model 在表单元素中的使用
v-model 在表单元素(如 、、)上的用法与 Vue 2 类似,仍然是对 :value 和 @input(或类似事件)的语法糖。
-
基本用法:
html<input v-model="message" />
-
等价于:
html<input :value="message" @input="message = $event.target.value" />
-
message 是响应式数据(通常通过 ref 或 reactive 定义)。
-
当用户输入时,input 事件触发,message 被更新,视图同步变化。
-
-
修饰符: Vue 3 支持与 Vue 2 相同的修饰符:
-
.lazy:在 change 事件而非 input 事件更新数据。
-
.number:将输入值转换为数字。
-
.trim:去除首尾空格。
-
示例:
html<input v-model.lazy.number.trim="message" />
-
-
不同表单元素的行为:
- 文本输入():绑定 value,监听 input 事件。
- 复选框():绑定 checked,监听 change 事件。
- 单选框():绑定 value,监听 change 事件。
- 下拉框():绑定 value,监听 change 事件。
-
示例:
html<script setup> import { ref } from 'vue'; const message = ref(''); const isChecked = ref(false); const selected = ref('option1'); </script><template><input v-model="message" placeholder="输入文本" /><input type="checkbox" v-model="isChecked" /><select v-model="selected"><option value="option1">选项 1</option><option value="option2">选项 2</option></select><p>输入: {{ message }}</p><p>复选框: {{ isChecked }}</p><p>下拉框: {{ selected }}</p> </template>
**2. **v-model 在自定义组件中的使用
Vue 3 对组件上的 v-model 进行了重大改进,提供了更灵活的 API 和多重绑定支持。
基本用法
在 Vue 3 中,组件上的 v-model 默认绑定 modelValue 属性(props)和 update:modelValue 事件,而非 Vue 2 的 value 和 input。
-
父组件:
html<custom-input v-model="message" />
-
等价于:
html<custom-input :modelValue="message" @update:modelValue="message = $event" />
-
-
子组件(CustomInput.vue):
html<script setup> defineProps(['modelValue']); defineEmits(['update:modelValue']); </script><template><input:value="modelValue"@input="$emit('update:modelValue', $event.target.value)"/> </template>
- 子组件接收 modelValue 作为 props。
- 子组件通过 $emit(‘update:modelValue’, newValue) 触发更新事件,通知父组件更新数据。
多重 v-model
Vue 3 支持在同一组件上使用多个 v-model,通过指定不同的参数(argument)来区分。
-
父组件:
html<custom-form v-model:name="name" v-model:age="age" />
-
子组件(CustomForm.vue):
html<script setup> defineProps(['name', 'age']); defineEmits(['update:name', 'update:age']); </script><template><input:value="name"@input="$emit('update:name', $event.target.value)"placeholder="输入姓名"/><inputtype="number":value="age"@input="$emit('update:age', $event.target.value)"placeholder="输入年龄"/> </template>
-
父组件完整示例:
html<script setup> import { ref } from 'vue'; import CustomForm from './CustomForm.vue'; const name = ref(''); const age = ref(18); </script><template><custom-form v-model:name="name" v-model:age="age" /><p>姓名: {{ name }}</p><p>年龄: {{ age }}</p> </template>
自定义 v-model 修饰符
Vue 3 允许为 v-model 定义修饰符,子组件可以通过 props 接收修饰符并处理。
-
父组件:
html<custom-input v-model.capitalize="message" />
-
子组件(CustomInput.vue):
html<script setup> defineProps({modelValue: String,modelModifiers: { default: () => ({}) } }); defineEmits(['update:modelValue']);function handleInput(event) {let value = event.target.value;// 根据修饰符处理输入if (modelModifiers.capitalize) {value = value.charAt(0).toUpperCase() + value.slice(1);}$emit('update:modelValue', value); } </script><template><input :value="modelValue" @input="handleInput" /> </template>
- modelModifiers 是一个特殊的 props,包含 v-model 的修饰符(如 { capitalize: true })。
- 子组件根据修饰符逻辑处理输入值并触发更新。
**3. **v-model 的原理(简述)
- 表单元素:v-model 是 :value 和 @input(或其他事件)的语法糖,依赖 Vue 的响应式系统(ref 或 reactive)和事件机制实现数据与视图的同步。
- 自定义组件:v-model 通过 modelValue 属性和 update:modelValue 事件实现父子组件的双向绑定。多重 v-model 和修饰符通过参数化的 props 和 emits 实现灵活性。
- Vue 3 使用 Composition API 和
**4. **注意事项
- 响应式数据:v-model 绑定的数据必须是响应式的(如 ref 或 reactive),否则无法触发视图更新。
- 事件命名:组件的 v-model 必须使用 update:xxx 事件命名约定(如 update:modelValue),否则无法正常工作。
- 性能:频繁的 v-model 更新可能影响性能,建议在复杂场景下使用防抖或节流。
- 兼容性:Vue 3 的 v-model 与 Vue 2 不完全兼容,迁移时需注意 value/input 改为 modelValue/update:modelValue。
**5. **总结
- Vue 3 的 v-model 在表单元素上延续了 Vue 2 的语法糖,但在组件上更灵活,支持多重绑定和自定义修饰符。
- 组件的 v-model 基于 modelValue 属性和 update:modelValue 事件,配合 defineProps 和 defineEmits 使用。
- 通过参数化的 v-model(如 v-model:name)和修饰符,开发者可以实现更复杂的数据绑定场景。
相关文章:
vue2,3:v-model的语法糖
Vue2的v-model 语法糖 **1. **v-model 的作用 v-model 是 Vue 中用于实现双向数据绑定的指令,主要用于表单元素(如 、、)和自定义组件。它简化了数据与视图之间的同步,使得开发者可以方便地处理用户输入。 **2. **v-model 的语…...
【深度学习】#10 注意力机制
主要参考学习资料: 《动手学深度学习》阿斯顿张 等 著 【动手学深度学习 PyTorch版】哔哩哔哩跟李牧学AI 目录 注意力提示生物学中的注意力提示查询、键和值 注意力汇聚注意力评分函数掩蔽softmax操作加性注意力缩放点积注意力 Bahdanau注意力多头注意力自注意力和位…...
Modbus总线协议智能网关协议转换案例解析:提升系统兼容性
Modbus是一种串行通信协议,是Modicon公司(现在的施耐德电气,Schneider Electic)于1979年为使用可编程逻辑控制器(PLC)通信而发表。Modbus已经成为工业领域通信协议的业界标准(Defacto),并日现在是工业电子设备之间常用的连接方式 Modbus是一种串行通信协…...
echarts自定义图表--仪表盘
基于仪表盘类型的自定义表盘 上图为3层结构组成 正常一个仪表盘配置要在外圈和内圈之间制造一条缝隙间隔 再创建一个仪表盘配置 背景透明 进度条拉满 进度条颜色和数据的背景相同开始处的线 又一个仪表盘配置 数值固定一个比较小的值 <!DOCTYPE html> <html><h…...
第五章:Execution Flow Framework
Chapter 5: Execution Flow Framework 从消息记忆到执行流程:如何让多个AI“同事”协同完成复杂任务? 在上一章的消息与记忆系统中,我们已经能让AI记住之前的对话内容。但你是否想过:如果用户要求“预订从北京到上海的高铁&#…...
01 C++概述
一、C语言发展史 起源与演进 • 1960s:剑桥大学Martin Richards开发BCPL语言,用于系统软件开发。 • 1970年:贝尔实验室Ken Thompson在BCPL基础上发明B语言。 • 1972年:Dennis Ritchie和Brian Kernighan设计出C语言,兼…...
Kotlin DSL 深度解析:从 Groovy 迁移的困惑与突破
引言 Gradle 作为现代构建工具,支持 Groovy 和 Kotlin 两种 DSL(领域特定语言)。Kotlin DSL 因其类型安全和更好的 IDE 支持逐渐流行,但它的语法设计却让许多开发者感到困惑,尤其是从 Groovy 迁移时。 本文将从 Kotl…...
2025年二级造价师考点总结
二级造价师考点总结 一、建设工程造价管理 工程造价构成:重点掌握建筑安装工程费(人工费、材料费、机械费、企业管理费、利润、规费、税金)的组成及计算。 计价依据:熟悉工程量清单计价规范,掌握定额计价与清单计价的…...
Typecho博客使用阿里云cdn和oss:handsome主题进阶版
Typecho使用阿里云cdn和oss 设置前需要保证阿里云cdn和oss已配置好且可以正常使用一、准备工作二、修改 Handsome 主题的静态资源链接方法 1:直接修改主题文件(推荐)方法 2:通过主题设置自定义(方便) 三、处…...
知识体系_用户研究_用户体验度量模型
1 用户体验度量常见模型 1.1 满意度(CSAT/PSAT) CSAT(Customer Satisfaction)指客户满意度,PAST(Product Satisfaction)指产品满意度。顾名思义,其用于衡量客户对产品或服务的体验度量指标。在用户完成某个产品或某项服务的体验后,对其进行…...
邮件分类特征维度实验分析
活动发起人小虚竹 想对你说: 这是一个以写作博客为目的的创作活动,旨在鼓励大学生博主们挖掘自己的创作潜能,展现自己的写作才华。如果你是一位热爱写作的、想要展现自己创作才华的小伙伴,那么,快来参加吧!…...
Linux服务之Nginx服务部署及基础配置
目录 一.Nginx介绍 1.Nginx功能介绍 2.基础特性 3.Web服务相关的功能 4.I/O模型相关概念 5.nginx模块 6.Nginx文件存放位置 7.Nginx事件驱动模型 二.平滑升级及信号使用 1.Nginx 程序当作命令使用 2.信号类型 3.平滑升级nginx 4.回滚 三.Nginx调优 1.隐藏版本号或…...
Centos小白之在CentOS8.5中安装Rabbitmq 3.10.8
注意事项 安装以及运行等其他操作,要使用root账号进行,否则会遇到很多麻烦的事情。 使用命令行进行远程登录 ssh root192.168.0.167 安装make 执行安装命令 yum -y install make gcc gcc-c kernel-devel m4 ncurses-devel openssl-devel这里有可能会…...
基于单片机的游泳馆智能管理系统设计与实现
标题:基于单片机的游泳馆智能管理系统设计与实现 内容:1.摘要 随着游泳馆规模的不断扩大和管理需求的日益提高,传统的管理方式已难以满足高效、精准的管理要求。本文旨在设计并实现一种基于单片机的游泳馆智能管理系统。采用单片机作为核心控制单元,结合…...
深度相机(一)——深度相机模型及用途介绍
一、深度相机概述 深度相机,又称 3D 相机,是一种能够获取场景中物体深度信息(即物体到相机的距离)的设备。与传统相机只能拍摄二维平面图像不同,深度相机不仅能记录物体的颜色和纹理,还能通过特定技术手段测…...
【Torch】nn.Conv1d、nn.Conv2d、nn.Conv3d算法详解
1. nn.Conv1d 1.1 输入(Input)和输出(Output) 输入张量 形状:(batch_size, in_channels, length) batch_size:一次过网络的样本数in_channels:每个样本的通道数(特征维度࿰…...
Android WebRTC回声消除
文章目录 安卓可用的回声消除手段各种回声消除技术优缺点WebRTC回声消除WebRTC回声消除回声消除处理流程WebRTC AECM APP 安卓可用的回声消除手段 硬件回声消除 使用 AudioRecord 的 VOICE_COMMUNICATION 模式:通过 AudioRecord 的 VOICE_COMMUNICATION 音频源可以…...
[Linux运维] [Ubuntu/Debian]在Lightsail Ubuntu服务器上安装Python环境的完整指南
在之前的教程中,我们已经讲过如何开通亚马逊Lightsail服务器并安装宝塔面板。今天,我们来进一步补充:如何在Lightsail上的Ubuntu/Debian系统中安装和配置Python开发环境。 本教程不仅适用于Lightsail服务器,也适用于所有使用Ubunt…...
2025医疗领域AI发展五大核心趋势与路线研究
引言 人工智能技术正在全球范围内深刻改变医疗服务的提供方式,推动全球医疗的普惠化、技术合作、产业升级以及公共卫生防控发生巨变[0]。医疗AI的浪潮奔涌向前,从2024年开始,生成式AI的爆发式发展更是将医疗AI推到了新的十字路口[1]。在这一背景下,本报告将深入探讨医疗领…...
【学习笔记】机器学习(Machine Learning) | 第六周|过拟合问题
机器学习(Machine Learning) 简要声明 基于吴恩达教授(Andrew Ng)课程视频 BiliBili课程资源 文章目录 机器学习(Machine Learning)简要声明 摘要过拟合与欠拟合问题一、回归问题中的过拟合1. 欠拟合(Underfit&#x…...
【MQ篇】RabbitMQ之惰性队列!
目录 引言:当“生产”大于“消费”,队列就“胖”了!肥宅快乐队列?🤔队列界的“躺平”大师:惰性队列(Lazy Queues)驾到!😴如何“激活”你的队列的“惰性”属性…...
计算机视觉——通过 OWL-ViT 实现开放词汇对象检测
介绍 传统的对象检测模型大多是封闭词汇类型,只能识别有限的固定类别。增加新的类别需要大量的注释数据。然而,现实世界中的物体类别几乎无穷无尽,这就需要能够检测未知类别的开放式词汇类型。对比学习(Contrastive Learning&…...
第二部分:网页的妆容 —— CSS(下)
目录 6 布局基础:Display 与 Position - 元素如何排列和定位6.1 小例子6.2 练习 7 Flexbox 弹性布局:一维布局利器7.1 小例子7.2 练习 8 Grid 网格布局:强大的二维布局系统8.1 小例子8.2 练习 9 响应式设计与媒体查询:适应不同设备…...
vite项目tailwindcss4的使用
1、安装taillandcss 前几天接手了一个项目,看到别人用tailwindcss节省了很多css代码的编写,所以自己也想在公司项目中接入tailwindcss。 官网教程如下: Installing Tailwind CSS with Vite - Tailwind CSS 然而,我在vite中按…...
css中:is和:where 伪函数
在 CSS 里,:is() 属于伪类函数,其作用是对一组选择器进行匹配,只要元素与其中任何一个选择器相匹配,就可以应用对应的样式规则。以下是详细介绍: 基本语法 :is() 函数的参数是一个或多个选择器,各个选择器之…...
线下零售数据采集:在精度与效率之间寻找平衡点
线下零售数据采集:在精度与效率之间寻找平衡点 为什么线下零售必须重视数据采集? 随着零售行业竞争加剧,门店执行的标准化与透明化成为供应链协作、销售提升的基础工作。 POG(陈列执行规范)的落地效果、陈列策略的调整…...
【Robocorp实战指南】Python驱动的开源RPA框架
目录 前言技术背景与价值当前技术痛点解决方案概述目标读者说明 一、技术原理剖析核心概念图解核心作用讲解关键技术模块说明技术选型对比 二、实战演示环境配置要求核心代码实现案例1:网页数据抓取案例2:Excel报表生成 运行结果验证 三、性能对比测试方…...
新ubuntu物理机开启ipv6让外网访问
Ubuntu 物理机 SSH 远程连接与 IPv6 外网访问测试指南 1. 通过 SSH 远程连接 Ubuntu 物理机 1.1 安装 SSH 服务 sudo apt update sudo apt install openssh-server1.2 检查 SSH 服务状态 sudo systemctl status ssh确认出现 active (running)。 1.3 获取物理机 IP 地址 i…...
驱动开发硬核特训 │ Regulator 子系统全解
一、Regulator子系统概述 在 Linux 内核中,Regulator 子系统是专门用于管理电源开关、电压调整、电流控制的一套完整框架。 它主要解决以下问题: 设备需要的电压通常不一样,如何动态调整?有些设备休眠时需要关闭供电࿰…...
入门版 鸿蒙 组件导航 (Navigation)
入门版 鸿蒙 组件导航 (Navigation) 注意:使用 DevEco Studio 运行本案例,要使用模拟器,千万不要用预览器,预览器看看 Navigation 布局还是可以的 效果:点击首页(Index)跳转到页面(…...
怎样将visual studio 2015开发的项目 保存为2010版本使用
用的老旧电脑跑vs2015太慢了,实在忍不了了! 想把用 Visual Studio 2015 的做的项目保存为 Visual Studio 2010 兼容的格式,以后都使用2010写了。自己在网上搜了一下,亲测以下步骤可以的 手动修改解决方案和项目文件 修改解决方案…...
【学习笔记】软件测试流程-测试设计阶段
软件测试设计阶段这个阶段主要工作是编写测试用例。 什么是测试用例? 测试用例(TestCase)是为项目需求而编制的一组测试输入、执行条件以及预期结果,以便测试某个程序是否满足客户需求。简而言之,测试用例是每一个测…...
Rust 学习笔记:关于切片的两个练习题
Rust 学习笔记:关于切片的两个练习题 Rust 学习笔记:关于切片的两个练习题引用和切片引用的大小以下程序能否通过编译? Rust 学习笔记:关于切片的两个练习题 参考视频: https://www.bilibili.com/video/BV1GrDQYeEzS…...
BeeWorks企业内部即时通讯软件支持国产化,已在鸿蒙系统上稳定运行
一、企业用户面临的困境与痛点 一些企业用的即时通讯软件比较旧,存在的问题不仅影响了日常工作的正常开展,也阻碍了企业信息化建设的进程: ● 国产系统与移动端不兼容:仅支持Windows和MAC系统,无法在银河麒麟、统信U…...
java对文字按照语义切分
实现目标 把一段文本按照一个完整的一句话为单元进行切分。如:以逗号,感叹号结尾看作是一个句子。 实现方案 StanfordCoreNLP切分 引入依赖 <dependency><groupId>edu.stanford.nlp</groupId><artifactId>stanford-corenlp<…...
华纳云:centos如何实现JSP页面的动态加载
JSP(JavaServer Pages)作为Java生态中常用的服务器端网页技术,具有动态内容生成、可扩展性强、与Java无缝结合等优势。 而CentOS作为一款稳定、高效、安全的Linux服务器操作系统,非常适合部署JSP应用。 想要让JSP页面实现动态更新加载,避免…...
Android 消息队列之MQTT的使用(二):会话+消息过期机制,设备远程控制,批量控制实现
目录 一、实际应用场景 室内温湿度数据上传设备远程控制批量控制实现 二、会话管理、消息过期设置 4.1 会话管理 Clean Session参数 新旧会话模式对比典型应用场景 4.2 消息过期设置 MQTT 5.0消息过期机制 Message Expiry Interval属性QoS级别影响 三、实际应用场景 …...
一、JVM基础概念
一、JVM的设计目标 一次编译,到处运行(跨平台) ➔ Java编译成字节码,由JVM在不同平台解释/编译执行,实现跨平台。 内存管理与垃圾回收 ➔ JVM统一负责内存分配和回收,降低内存泄漏的风险。 性能优化 ➔ JIT(即时编译…...
深度学习---Pytorch概览
一、PyTorch 是什么? 1. 定义与定位 开源深度学习框架:由 Facebook(Meta)AI 实验室开发,基于 Lua 语言的 Torch 框架重构,2017 年正式开源,主打动态计算图和易用性。核心优势:灵活…...
第33周JavaSpringCloud微服务 分布式综合应用
第33周JavaSpringCloud微服务 分布式综合应用 一、分布式综合应用概述 分布式知识体系内容广泛,主要包括分布式事务、分布式锁、RabbitMQ等消息中间件的应用以及跨域问题的解决。 1.1 课程重点内容介绍 分布式事务 :在大型项目中普遍存在,…...
Paramiko 完全指南
目录 Paramiko 概述核心功能与模块框架安装与依赖基础用法与案例详解 SSH 连接与命令执行密钥认证SFTP 文件传输交互式会话端口转发 高级功能与实战技巧常见问题与解决方案总结与资源推荐 1. Paramiko 概述 是什么? Paramiko 是一个纯 Python 实现的 SSHv2 协议库…...
夜莺监控V8(Nightingale)二进制部署教程(保姆级)
夜莺监控部署 前置工作 1. 部署好mysql 2. 部署好redis 3. 部署好prometheus夜莺压缩包下载 本教程基于Centos7系统下的二进制方式部署,先去官网进行压缩包下载 在系统创建/opt/n9etest目录,并将压缩包拖进目录 mkdir /opt/n9etest进入/opt/n9etest࿰…...
鸿蒙应用开发 知识点 官网快速定位表
ArkTS 语言介绍 ArkTS 语言介绍 基础入门 资源分类与访问 添加组件(基础组件) 显示图片 (Image) 按钮 (Button) 单选框 (Radio) 切换按钮 (Toggle) 进度条 (Progress) 视频播放 (Video) 使用文本 文本显示 (Text/Span) 文本输入 (TextInput/TextArea) 使用弹窗 使用弹…...
【神经网络与深度学习】两种加载 pickle 文件方式(joblib、pickle)的差异
引言 从深度学习应用到数据分析的多元化需求出发,Python 提供了丰富的工具和模块,其中 pickle 和 joblib 两种方式在加载数据文件方面表现尤为突出。不同场景对性能、兼容性以及后续处理的要求不尽相同,使得这两种方式各显优势。本文将通过深…...
quickbi finebi 测评(案例讲解)
quickbi & finebi 测评 国产BI中入门门槛比较低的有两个,分别是quickbi和finebi。根据我的经验通过这篇文章做一个关于这两款BI的测评文章。 quickbi分为个人版、高级版、专业版、私有化部署四种。这篇文章以quickbi高级版为例,对quickbi进行分享。…...
vue的生命周期 以及钩子
最早可以在created 时调用后端接口获取数据,因为beforecreated的时候 那个data 都还还是初始化出来 修改数据的时候触发 update 案例1:create 案例2:一进来页面获取搜索框焦点 echarts 饼图渲染 初始化dom后才去准备实例,所以必须要在dom之后…...
Mariadb 防火墙服务器和端口:mysql | 3306
Centos7 Mariadb 理解:Mariadb数据库就类似于我们生活中常见的Excel。 主要工作原理就是我们创造一个数据库其中创造一个数据表再在数据表中输入内容,分为三类。在详细点就是打开Excel(数据库),我们在其中加入…...
爬虫学习笔记(二)--web请求过程
Web请求全过程(重要) 从输入完网址(如输入百度网址)到返回页面以及页面中的数据这一完整的过程发生了什么事情? 服务器端渲染 在服务器端直接把数据和html整合,统一返回给浏览器,在页面源代码…...
开发vue项目所需要安装的依赖包
在开发Vue项目时,通常需要安装以下几个核心依赖包:1、Vue CLI、2、Vue Router、3、Vuex、4、Axios。这些依赖包可以确保你的Vue项目拥有基础的功能和良好的开发体验。接下来,我们将详细介绍每个依赖包的作用、安装方法以及使用案例。 一、VUE…...
Java SE(4)——方法详解
1.方法的概念&使用 1.1 什么是方法? Java中的方法类似于C语言中的函数,是用于执行特定任务的代码块。 那么用方法组织起来的代码块和普通的代码相比有什么优势呢? 1.当代码规模较大且应用场景较为复杂时,方法能够模块化地组…...