学习文档(4)

news2025/1/15 6:39:15

目录

Vue简介

MVVM思想

Vue指令

内容输出指令

条件渲染指令

列表渲染指令

数据绑定指令


Vue简介

Vue2.x官网:https://v2.cn.vuejs.org

Vue3.x官网:https://cn.vuejs.org

官网(2.x版本)对vue的定义是:vue是一套用于构建用户界面的渐进式框架。与其他大型框架不同的是,Vue被设计为可以自底向上逐层应用。Vue的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue也完全能够为复杂的单页应用提供驱动。

使用Vue.js可以让Web开发变得简单,它提供了许多现代Web开发常用的高级功能:

  • 解耦视图和数据
  • 可复用的组件
  • 前端路由
  • 状态管理
  • 虚拟DOM(virtual|DOM)

MVVM思想

Vue设计上使用的MVVM(Model-View-ViewModel)模式

  • Model:模型,负责存储和提供数据
  • View:视图,负责页面展示
  • ViewModel:视图模型,是View和Model之间的桥梁。它负责处理View和Model之间的交互,比如将Model的数据转换为View可以展示的格式,或者将用户在View的操作转换为Model的数据更新

MVVM将View的状态和行为抽象,把视图层和业务逻辑层分离,ViewModel就是完成这些工作的。

MVVM模式的优势

  • 低耦合:View可独立于Model变化和修改,一个ViewModel可以绑定到不同的View上,当View变化时Model可以不变,当Model变化时View也可以不变。
  • 可重用性:由于三个部分相对独立,所以可重用性高,一个Model可以用于多个View,一个ViewModel的业务逻辑也可以作用于多个View
  • 独立开发:同样由于独立性,设计人员可以专注于View视图的开发,擅长业务逻辑的开发人员可以专注开发ViewModel,更易于团队合作

Vue指令

指令(Directives)是特殊的带有前缀 v- 的特性。指令的职责就是其表达式的值改变时把某些特殊的行为应用到DOM上。

内容输出指令

v-text和v-html主要负责渲染数据为标签内容

    <div id="app">
        <!-- JSON变量 -->
        <p>{{msg}}</p>
        <!-- 数字类型 -->
        <p>{{98}}</p>
        <!-- 字符串类型 -->
        <p>{{"Hello Vue!"}}</p>
        <!-- JavaScript表达式 -->
        <p>{{"Hello" + name}}</p>
        <p>{{10 / 5}}</p>
        <!-- 三元表达式 -->
        <p>{{ ok ? 'YES':'NO'}}</p>
        <p>{{msg.split('').reverse().join('')}}</p>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
    <script>
        const app = new Vue({
            el : "#app",
            data : {
                msg : "Musrache语法",
                name : "菲菲",
                ok : true
            }
        })
    </script>

运行效果

使用插值和v-text指令的方式显示html代码时,并不渲染为html解析结果,而是作为文本内容输出,类似于jQuery的text()方法,而v-html指令会将html解析结果渲染,类似于jQuery中的html()方法

条件渲染指令

作为模板语言,条件判断也是必不可少的,其中v-if和v-else指令是控制元素是否需要出现在DOM树结构中,注意v-else指令必须紧跟着v-if指令的后面,中间不能添加其他元素。而v-show是控制元素是否需要显示在页面中,此元素会一直存在于DOM树结构中

    <div id="app">
        <div v-if="ok">我是v-if指令控制的DIV</div>
        <div v-else>我是v-else指令控制的DIV</div>
        <div v-show="show">我是v-show指令控制的DIV</div>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
    <script>
        const app = new Vue({
            el : "#app",
            data : {
                ok : true,
                show : true
            }
        })
    </script>

效果图

我们设置数据ok为true,show也为true,查看浏览器运行效果,并键入F12打开”开发者工具“中的Elements选项卡,查看对应的DOM结构,可以发现我们写了3个DIV元素,但是在DOM结构中只有v-if和v-show的DIV存在,v-else对应的DIV因为不满足条件,被删除了。

接下来我们把ok和show都设置为false

            data : {
                ok : true,
                show : true
            }

运行结构如图所示,页面只显示了v-else指令内容,而v-show是通过将CSS样式中display设置为none的方式隐藏的,依然存在于DOM结构中

下面我们总结一下v-if 和 v-show的区别,v-if控制的是元素是否需要出现在DOM结构中,作用时添加和删除元素,v-show控制的是元素的隐藏和显示,无论是否显示都一直在DOM结构中。其各自的使用场景为:

  • v-if指令有更高的切换消耗,因为条件成立时是需要通过添加元素改变DOM树结构的,不成立时又要删除元素并且内部指令不执行,如果频繁的显示和隐藏性能消耗大,适合首次加载时是否需要渲染,后续不再更改条件
  • v-show无论条件是否成立,元素都必须添加到DOM树中,所以有更高的初始渲染消耗,通过CSS样式来控制是否显示,性能消耗小,适合频繁切换显示隐藏的元素

列表渲染指令

v-for指令课遍历data中的数据,根据循环次数生成被指令修饰的DOM元素。

<div id="app">
        <ul>
            <!-- 使用v-for修饰的li标签会重复生成 -->
            <!-- course是循环元素(课程),index是下标 -->
            <li v-for="(course,index) in courses" :key="index">
                {{index}}、课程:{{course.name}}
                <ul>
                    <!-- 循环嵌套,显示课程的章节信息 -->
                    <li v-for="(chapter,idx) in course.chapters" :key="idx">
                        {{idx}}、章节:{{chapter.name}} 课时:{{chapter.lesson}}
                    </li>
                </ul>
            </li>
        </ul>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
    <script>
        const app = new Vue({
            el : "#app",
            data : {
                courses : [
                    {
                        name : "前端框架入门" , chapters:[
                            {name : "Vue.js",lesson : 4},
                            {name : "React.js",lesson : 8},
                            {name : "Angular.js",lesson : 16}
                        ]
                    },
                    {
                        name : "后端框架入门", chapters:[
                            {name : "MyBatis",lesson : 8},
                            {name : "Spring",lesson : 8},
                            {name : "SpringMVC",lesson : 16}
                        ]
                    }
                ]
            }
        })
    </script>

效果图

注意:key属性能够为每项提供一个唯一的标识,理性的key是数据的唯一键,示例代码中使用index小标实际上是不恰当的,如果删除或者新增数据,下标是会方式变化的,可能导致各种问题出现,所以 key属性建议使用数据中每项的唯一键,比如ID作为key

数据绑定指令

v-model指令能够实现表单输入与数据的双向绑定,双向绑定指的是在Vue实例对象中的data与其渲染的DOM元素内容保持一致,无论哪一方被改变,另一方也会相应的更新。

v-model只能使用在 <input>、<select>、<textarea> 等表单元素上,与其值进行双向绑定

<div id="app">
        <!-- 写死src,不能动态改变 -->
        <img src="images/vue.png"/>
        <!-- 使用v-bind指令,可动态改变src -->
        <img v-bind:src="imageSrc"/>
        <!-- 简写写法 -->
        <img :src="imageSrc"/>
        <!-- 绑定对象,则属性值为true的添加,false的不添加 -->
        <p v-bind:class="{ class: hasA, classB: hasB }">段落1</p>
        <!-- 绑定数组,则数组中的样式都会添加 -->
        <p v-bind:class="classArray">段落2</p>
    </div>
    <script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
    <script>
        const app = new Vue({
            el : "#app",
            data : {
                imageSrc : 'images/vue.png',
                hasA : false,
                hasB : true,
                classArray : ['classA','classC']
            }
        });
        setTimeout(function(){
            // 3秒后修改图片属性值,查看图片是不是变化了
            app.imageSrc = 'images/react.png';
        },3000)
    </script>

效果图(刚加载)

效果图(3秒后)

在运行实例代码后,我们需要等待3秒后,可以看到两张图片的变化,因为我们通过Vue实例对象修改了imageSrc这个属性,导致用v-bind:src绑定此属性的两张图片的src跟着变化

效果图(段落结构)

而在“开发者工具”周的Element选项卡,会方向段落1中只用到了类样式classB,因为hasB为true值。段落2则使用了数组,所以类样式ClassA和ClassC都存在

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

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

相关文章

kubelet PLEG实现

概述 kubelet的主要作用是确保pod状态和podspec保持一致&#xff0c;这里的pod状态包括pod中的container状态&#xff0c;个数等。 为了达到这个目的&#xff0c;kubelet需要从多个来源watch pod spec的变化&#xff0c;并周期从container runtime获取最新的container状态。比如…

I2C相关结构体讲解:i2c_adapter、i2c_algorithm、i2c_msg

往期内容 I2C子系统专栏&#xff1a; I2C&#xff08;IIC&#xff09;协议讲解SMBus 协议详解 总线和设备树专栏&#xff1a; 专栏地址导航篇 – 专栏未篇 1.框图 建议右击图片在新标签页打开预览 i2c_transfer函数就是读取i2c设备的信息或者输出信息给i2c设备的函数 比如发送…

信息安全工程师(49)网络物理隔离系统与类型

前言 网络物理隔离系统是指通过物理隔离技术&#xff0c;在不同的网络安全区域之间建立一个能够实现物理隔离、信息交换和可信控制的系统&#xff0c;以满足不同安全域的信息或数据交换需求。 一、网络物理隔离系统概述 网络物理隔离系统的核心在于通过物理方式将不同安全级别的…

SQL Injection | SQL 注入概述

关注这个漏洞的其他相关笔记&#xff1a;SQL 注入漏洞 - 学习手册-CSDN博客 0x01&#xff1a;SQL 注入漏洞介绍 SQL 注入就是指 Web 应用程序对用户输入数据的合法性没有判断&#xff0c;前端传入后端的参数是可控的&#xff0c;并且参数会带入到数据库中执行&#xff0c;导致…

【计算机网络篇】数据链路层 协议、介质访问控制

&#x1f9f8;安清h&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;【计算机网络】【Mybatis篇】 &#x1f6a6;作者简介&#xff1a;一个有趣爱睡觉的intp&#xff0c;期待和更多人分享自己所学知识的真诚大学生。 系列文章目录 【计算机网络篇】计算机网络概述 【…

[实时计算flink]CREATE DATABASE AS(CDAS)语句

CDAS支持整库级别的表结构和数据的实时同步&#xff0c;还支持表结构变更的同步。本文为您介绍CREATE DATABASE AS&#xff08;CDAS&#xff09;的使用方法&#xff0c;并提供了多种使用场景下的示例。 背景信息 CDAS是CTAS语法的一个语法糖&#xff0c;用于实现整库同步、多…

在 Unity 中创建模型动画的探索之旅

在 Unity 游戏开发或 3D 场景构建中&#xff0c;模型动画是赋予虚拟对象生命和个性的关键元素。它能够极大地增强用户体验&#xff0c;使场景更加生动和吸引人。本文将带您深入了解在 Unity 中创建模型动画的基本流程和方法。 一、准备工作 在开始创建动画之前&#xff0c;您…

空间大数据的数据变换与价值提炼

在数字化时代&#xff0c;空间大数据正成为推动社会经济发展的关键因素。空间大数据不仅体量巨大&#xff0c;而且具有高速流转、多样类型和真实性等特点&#xff0c;它们在获取、存储、管理、分析方面超出了传统数据库软件工具的能力范围。地理信息系统&#xff08;GIS&#x…

淘宝详情API接口有什么用处?

淘宝详情API接口有什么用处&#xff1f;主要体现在以下几个方面&#xff1a; 电商数据分析&#xff1a;通过调用API接口获取商品详情数据&#xff0c;可以对商品的销售情况、价格变化、属性分布等进行深入分析。这些数据为电商运营提供了决策支持&#xff0c;帮助商家更好地了…

Redis哨兵模式部署(超详细)

哨兵模式特点 主从模式的弊端就是不具备高可用性&#xff0c;当master挂掉以后&#xff0c;Redis将不能再对外提供写入操作&#xff0c;因此sentinel模式应运而生。sentinel中文含义为哨兵&#xff0c;顾名思义&#xff0c;它的作用就是监控redis集群的运行状况&#xff0c;此…

使用gradle将java项目推送至maven中央仓库(最新版)

前言 maven中央仓库于2024年3月进行改版&#xff0c;下面介绍新的推送方式 一、将项目推送到github 过程略 二、注册sonatype账号 仓库地址&#xff1a;https://central.sonatype.com/ 这里选择使用github账号登录&#xff0c;不注册新的了 三、创建命名空间 这里会自动…

2012年国赛高教杯数学建模D题机器人避障问题解题全过程文档及程序

2012年国赛高教杯数学建模 D题 机器人避障问题 图1是一个800800的平面场景图&#xff0c;在原点O(0, 0)点处有一个机器人&#xff0c;它只能在该平面场景范围内活动。图中有12个不同形状的区域是机器人不能与之发生碰撞的障碍物&#xff0c;障碍物的数学描述如下表&#xff1a…

uniapp 整合 OpenLayers - 加载Geojson数据(在线、离线)

Geojson数据是矢量数据&#xff0c;主要是点、线、面数据集合 Geojson数据获取&#xff1a;DataV.GeoAtlas地理小工具系列 实现代码如下&#xff1a; <template><!-- 监听变量 operation 的变化&#xff0c;operation 发生改变时&#xff0c;调用 openlayers 模块的…

牛只行为及种类识别数据集18g牛只数据,适用于多种图像识别,目标检测,区域入侵检测等算法作为数据集。数据集中包括牛只行走,站立,进食,饮水等不同类型的数据

18g牛只数据&#xff0c;适用于多种图像识别&#xff0c;目标检测&#xff0c;区域入侵检测等算法作为数据集。 数据集中包括牛只行走&#xff0c;站立&#xff0c;进食&#xff0c;饮水等不同类型的数据&#xff0c;可以用于行为检测 数据集中包含多种不同种类的牛只&#xff…

Eking管理易 Html5Upload 前台任意文件上传漏洞复现

0x01 产品描述&#xff1a; ‌Eking管理易是一款专为广告制品制作企业量身定制的管理软件产品&#xff0c;旨在帮助企业实现规范化、科学化管理&#xff0c;提升运营效率和降低运营成本。‌ 该软件由广州易凯软件技术有限公司开发&#xff0c;基于JAVA企业版技术研发&#xff0…

CSS 入门

1. CSS 1.1 概念 CSS&#xff08;Cascading Style Sheet&#xff09;&#xff0c;层叠样式表&#xff0c;用于控制页面的样式 CSS 能够对网页中元素位置的排版进行像素级精确控制&#xff0c;实现美化页面的效果&#xff0c;能够做到页面的样式和结构分离&#xff08;类似于…

Wi-Fi数据帧类别

网络中传送的业务数据对服务质量&#xff08;QualityofService&#xff0c;QoS&#xff09;有不同的要求&#xff0c;例如语音业务需要实时被传送&#xff0c;它对时延的大小很敏感。当W-Fi MAC层在同时传输语音业务和普通业务的数据时&#xff0c;语音业务就需要被高优先级发送…

当下的时代?

我这两天刚接触一个人,错误之皇,每做一件小事的时候他都像救命稻草一样抓着,有一天我一看,嚯,好家伙,他抱着的是已经让我仰望的参天大树了! 这个时代需要我们从无限思维的视角和做法去努力&#xff1b;它不取决于我们现在有多少&#xff0c;而取决于我们未来的成长幅度是多少&a…

动态规划算法专题(七):两个数组的dp问题

目录 1、最长公共子序列 1.1 算法原理 1.2 算法代码 2、不相交的线 2.1 算法原理 2.2 算法代码 3、不同的子序列 3.1 算法原理 3.2 算法代码 4、通配符匹配&#xff08;hard ★★★&#xff09; 4.1 算法原理 4.2 算法代码 5、正则表达式匹配&#xff08;hard ★…

Vue-admin-box后台管理框架

文章目录 1、项目概述2、技术栈3、 特色功能4、基础模板5、 项目演示6、 源码地址7、 演示地址8、小结Vue-Admin-Box,一款精心打造的Vue.js后台管理模板,旨在为开发者提供高效、美观且易于扩展的后台解决方案。它集成了现代Web开发的最佳实践,包括响应式设计、模块化开发、丰…