【Vue基本指令】一.什么是Vue;二.Vue开发的方式;三.Vue的基本指令(重点)

news2024/11/17 3:44:03

目录

一.什么是Vue

1.前端技术的发展(html、CSS、JavaScript)

(1)JQuery:是对JavaScript进行了封装,使得操作DOM、事件处理、动画处理、Ajax交互变得非常简洁、方便。是JavaScript的库。

(2)Vue:通过虚拟的DOM来减少对真实DOM的操作,通过尽可能少的、简单的API实现数据的绑定。支持单向和双向的数据绑定

(3)Vue的基本概念:

2.MVVM架构:

(1)MVC架构:模型——视图——控制器

(2)MVVM架构:

二.Vue开发的方式

1.基本方式:在页面中引入vue.js文件。(vscode)

2.组件方式:利用Vue-cli(Vue脚手架)开发。(vscode、WebStorm、Vue Gui)

3.创建Vue实例:new Vue({})

(1)el:表示与vue实例绑定的唯一的根标签。是通过标签的id或class属性进行绑定

(2)data:初始化vue实例的属性的值。在底层会自动生成属性的setter和getter方法

(3)methods:用来定义方法。这些方法vue的实例可以直接访问

三.Vue的基本指令(重点)

1.插值表达式:{{ 变量名 }}。将Vue实例的对应的属性值在页面中显示出来

2.内置指令:vue的内置指令都是以 v- 开头的 特殊属性,通过这些指令来操作属性的值

(1)v-show:可以根据表达式的值的真假,来决定是否显示数据

(2)v-html:插入标签

(3)v-text:在元素中插入值。作用和插值表达式 {{ }}相同

(4)v-if、v-else、v-else-if:类似于if-else 的功能

(5)v-for:循环指令,用于遍历数组、集合、对象的属性

(6)v-bind:绑定元素的属性,并执行相关操作。简写方式为( :属性名 )

(7)v-on:监听事件,并执行相应的操作

(8)v-model:将input标签的值和变量进行绑定,实现数据和视图的双向绑定

(9)v-once:可以让元素或组件只渲染一次,一旦绑定,数据就不会改变。


一.什么是Vue

1.前端技术的发展(html、CSS、JavaScript)

(1)JQuery:是对JavaScript进行了封装,使得操作DOM、事件处理、动画处理、Ajax交互变得非常简洁、方便。是JavaScript的库。

(2)Vue:通过虚拟的DOM来减少对真实DOM的操作,通过尽可能少的、简单的API实现数据的绑定。支持单向和双向的数据绑定

(3)Vue的基本概念:

a.是一个渐进式框架:可以实现自底向上的逐层开发。

b.可以用Vue开发全新的项目,也可以在现有的项目中引入Vue

2.MVVM架构:

(1)MVC架构:模型——视图——控制器

M:Model(模型),对数据进行操作

V:View(视图),用来展示数据

C:Controller(控制器),处理用户的请求

(2)MVVM架构:

M:Model(模型)

V:View(视图)

VM:ViewModel(视图模型),实现数据的双向绑定

数据的双向绑定:Vue的特征之一,当视图发生改变时,模型能立即感知到;当模型中的数据发生改变时,视图也能立即反应出来。

二.Vue开发的方式

1.基本方式:在页面中引入vue.js文件。(vscode)

2.组件方式:利用Vue-cli(Vue脚手架)开发。(vscode、WebStorm、Vue Gui)

3.创建Vue实例:new Vue({})

(1)el:表示与vue实例绑定的唯一的根标签。是通过标签的id或class属性进行绑定

(2)data:初始化vue实例的属性的值。在底层会自动生成属性的setter和getter方法

可以是用 vue对象名.$data.属性名 的方式来获取值

(3)methods:用来定义方法。这些方法vue的实例可以直接访问

三.Vue的基本指令(重点)

1.插值表达式:{{ 变量名 }}。将Vue实例的对应的属性值在页面中显示出来

2.内置指令:vue的内置指令都是以 v- 开头的 特殊属性,通过这些指令来操作属性的值

(1)v-show:可以根据表达式的值的真假,来决定是否显示数据

(2)v-html:插入标签

 

(3)v-text:在元素中插入值。作用和插值表达式 {{ }}相同

(4)v-if、v-else、v-else-if:类似于if-else 的功能

强调:v-show和v-if的区别

A.实现方式:v-if底层采用appendChild方式实现,v-show是通过样式属性display来控制元素的显示和隐藏

B.加载性能:v-if的加载速度更快,v-show的加载速度慢

C.切换的开销:v-if开销大,v-show的开销小

v-if是条件渲染。将模型中的数据在视图中显示出来的过程称为渲染

(5)v-for:循环指令,用于遍历数组、集合、对象的属性

 

 

课堂练习:将上例中objArr的数据显示在table中

(6)v-bind:绑定元素的属性,并执行相关操作。简写方式为( :属性名 )

(7)v-on:监听事件,并执行相应的操作

强调:v-on的简写方式(@事件名)

(8)v-model:将input标签的值和变量进行绑定,实现数据和视图的双向绑定

<div id="app">
        <p>性别:</p>
        <input type="radio" name="sex" value="男" v-model="gender">男
        <input type="radio" name="sex" value="女" v-model="gender">女
        <p>你选择的性别是:{{ gender }}</p>
        <hr>
       <p>地理分类:</p>
       <select v-model="book">
         <optgroup label="华东地区">
            <option value="江苏">江苏</option>
            <option value="浙江">浙江</option>
            <option value="广东">广东</option>
         </optgroup>
         <optgroup label="西北地区">
            <option value="陕西">陕西</option>
            <option value="甘肃">甘肃</option>
            <option value="宁夏">宁夏</option>
         </optgroup>
       </select> 
       <p>你选择的地区是:{{ book }}</p>
       <hr>
       <p>兴趣爱好:</p>
       <input type="checkbox" name="chk" value="游戏" v-model="hobby">游戏
       <input type="checkbox" name="chk" value="篮球" v-model="hobby">篮球
       <input type="checkbox" name="chk" value="象棋" v-model="hobby">象棋
       <input type="checkbox" name="chk" value="游泳" v-model="hobby">游泳
        <p>你的爱好是:{{ hobby }}</p>
        <hr>
        <label>
            姓名:<input type="text" v-model="userName">
        </label>
        <br><br>
        <p>你的姓名是:{{ userName }}</p>
    </div>
    <script>
        const vm = new Vue({
            el: '#app',
            data: {
                gender:'',
                book:'',
                hobby:[],
                userName: ''
            }
        })
    </script>

(9)v-once:可以让元素或组件只渲染一次,一旦绑定,数据就不会改变。

课堂练习1:实现如图所示的菜单效果

<style>
    body{
        width: 600px;
    }
    a{
        text-decoration: none; /* 去掉下划线 */
        display: block;
        color: #fff; /* 字体颜色 */
        width: 120px;
        height: 40px;
        line-height: 40px;
        border: 1px solid #fff;
        border-width: 1px 1px 0 0;
        background: #255f9e;
    }
    li{
        list-style-type: none;
    }
    #app > li{
        float: left;
        text-align: center;
        position: relative;
    }
    #app li a:hover{
        color: #fff;
        background: #ffb100;
    }
    #app li ul{
        position: absolute;
        left: -40px;
        top: 40px;
        margin-top: 1px;
        font-size: 12px;
    }
</style>
<body>
    <div id="app">
        <li v-for="menu in menus" @mouseover="menu.show = !menu.show" @mouseout="menu.show = !menu.show">
            <a :href="menu.url">{{ menu.name }}</a>
            <ul v-show="menu.show">
                <li v-for="sub in menu.subMenus">
                    <a :href="sub.url">{{ sub.name }}</a>
                </li>
            </ul>
        </li>
    </div>
    <script>
        const vm = new Vue({
            el:'#app',
            data: {
                menus: [
                    {
                        name:'我的淘宝', //主菜单的名称
                        url: '#', //主菜单对应的地址
                        show: false, //是否显示子菜单
                        subMenus: [ //子菜单的列表
                            {
                                name: '已买到的宝贝',
                                url: '#'
                            },
                            {
                                name: '已卖出的宝贝',
                                url: '#'
                            }
                        ]
                    },
                    {
                        name: '收藏夹',
                        url: '#',
                        show: false,
                        subMenus:[
                            {
                                name: '收藏的宝贝',
                                url: '#'
                            },
                            {
                                name: '收藏的店铺',
                                url: '#'
                            }
                        ]
                    }
                ]
            }
        })
    </script>

 课堂练习2:音乐播放器

<style>
    .active{
        background: red;
    }
</style>
<body>
    <div id="app">
        <audio :src="songs[currentIndex].songUrl" controls autoplay></audio>
        <ul>
            <li v-for="song in songs" @click="play(song.id)" :class="{active: song.id === currentIndex+1}">
                <h2>歌名:{{ song.name }}</h2>
                <p>歌手:{{ song.artist }}</p>
            </li>
        </ul>
    </div>
    <script>
        const vm = new Vue({
            el: '#app',
            data: {
                songs:[
                    {
                        id: 1,
                        name: '别知己', //音乐名
                        songUrl: './audio/别知己.mp3', //音乐地址
                        artist:'潇斌' //歌手
                    },
                    {
                        id: 2,
                        name: '西海情歌',
                        songUrl: './audio/西海情歌.mp3',
                        artist:'刀郎'
                    },
                    {
                        id:3,
                        name: '粉丝记事本',
                        songUrl: './audio/粉丝记事本.mp3',
                        artist: '徐誉滕'
                    }
                ],
                currentIndex: 0  //当前用户选择的音乐的下标
            },
            methods: {
                play(id){
                    this.currentIndex = id - 1
                }
            }
        })
    </script>
</body>

 

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

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

相关文章

《云原生》一文搞懂RocketMQ队列概述

目录 序 概念简述 一、客户端概念 1. Topic-主题 2.ConsumerGroup&#xff08;消费者组&#xff09; 概念一览图 二、消息传输模型 三、实践应用 1.配置文件 2.生产者 3.消费者 配置一览图 最后的话 序 接上一篇对rabbitMQ队列进行了梳理 《一文搞懂rabbitMQ消息…

shell技术

退出状态码 Shell 中运行的命令会使用0-255之间的整数值&#xff0c;作为退出状态码,并以此来告知shell该命令执行的状态。 通常情况下&#xff0c;约定0代表命令成功结束&#xff0c;非0代表程序非正常退出。 假如没有指定返回值&#xff0c;那么会用脚本的最后一个命令的执…

华为路由器配置笔记

路由器(Router),是连接因特网中各局域网、广域网的设备,它会根据信道的情况自动选择和设定路由,以最佳路径,按前后顺序发送信号,路由器工作在网络层,用来跨网段通信,路由器具有判断网络地址和选择IP路径的功能,它能在多网络互联环境中,建立灵活的连接,可用完全不同的数据分组和…

巧用数据分析表达式,让数据指标创建更简单

实现数据业务一体化的指标分析 从零售系统进化史get 数据统计的需求变更 零售系统需要的数据统计需求 V1.0 只需要获取当日累计的销售额&#xff0c;于是店老板就用 Excel或者纸质的表格创建了一个表&#xff0c;表中包含销售的日期时间&#xff0c;销售的产品&#xff0c;销…

c语言的变量和指针,怎么理解?

学会应用指针是C语言程序员的分水岭&#xff0c;也是C程序员级别的试金石。 变量可以分为基础变量、数组变量、指针变量&#xff0c;其中数组变量非常特殊&#xff0c;可以进一步分为基础数组变量和指针数组变量&#xff0c;所以暂时不考虑数组变量。假设我们在32位计算机上工…

【云原生】k8s之pod基础(下)

内容预知 1.pod的镜像拉取策略 1.1 镜像拉取说明 1.2 镜像拉取的策略 1.3 镜像拉取策略的设置操作 &#xff08;1&#xff09;Never策略的使用 &#xff08;2&#xff09;IfNotPresent策略在本地无镜像的情况下使用 &#xff08;3&#xff09; IfNotPresent策略在本地有…

客观认识植物乳杆菌 (L. plantarum) 及其健康益处

人体消化系统包含大约几百到几千种不同的细菌种类&#xff0c;其丰度构成因人而异。 其中少数益生菌乳杆菌属&#xff0c;即嗜酸乳杆菌、植物乳杆菌、短乳杆菌、乳酸乳杆菌、干酪乳杆菌、保加利亚乳杆菌、发酵乳杆菌、鼠李糖乳杆菌特异性产生细胞外蛋白、胞外多糖、细菌素和脂磷…

信息安全治理-信息安全状态示例

声明 本文是学习github5.com 网站的报告而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 信息安全治理-信息安全状态示例 组织可以生成一个信息安全状态&#xff0c;并将其作为信息安全的沟通工具披露给利益相关者。 组织宜选择和决定信息安全状态的格…

Curve 分布式存储在 KubeSphere 中的实践

Curve 介绍 Curve 是网易开发的现代存储系统&#xff0c;目前支持文件存储 (CurveFS) 和块存储 (CurveBS)。现在它作为一个沙盒项目托管在 CNCF。 Curve 是一个高性能、轻量级操作、本地云的开源分布式存储系统。Curve 可以应用于 : 1) 主流云本地基础设施平台 OpenStack 和…

【Bigdata】【Java】用IDEA创建一个Maven项目时,一直卡在Generating project in Batch mode步骤

Project Scenario&#xff08;项目场景&#xff09;&#xff1a; I want to create a Maven project with IDEA to practice writing UDF functions and upload it to hdfs, so I need to initialize the maven project. &#xff08;本人想用IDEA创建一个Maven项目来练习UDF函…

Netty初探

序&#xff1a; 为什么打算写Netty 相关的博客呢&#xff1f; Netty如今已经是应用非常广泛了&#xff0c; 很多框架底层都能看到他的影子&#xff0c;如Dubbo , Spring Gateway &#xff0c; RocketMQ、Elasticsearch、HBase 等比较出名的框架&#xff0c;在性能&#xff0c;…

使用div+css实现表格布局

DIVCSS是WEB设计标准&#xff0c;它是一种网页的布局方法。与传统中通过表格&#xff08;table&#xff09;布局定位的方式不同&#xff0c;它可以实现网页页面内容与表现相分离。提起DIVCSS组合&#xff0c;还要从XHTML说起。XHTML是一种在HTML&#xff08;标准通用标记语言的…

【MySQL】【systemd】mysqld_pre_systemd 及 mysqld@.service 的 bugs

mysqld_pre_systemd 及 mysqld.service 的 bugs问题原理mysqld_pre_systemd 的 bugsmysqld.service 的 bugs测试案例重现不指定 datadir 和 log-error 的 bugs开启 SELinux &#xff0c;指定不同于默认值的自定义数据目录和错误日志位置进行测试修正方法方法一&#xff1a;向 m…

【Word】MathType 运行时错误‘53’:文件未找到:MathPage.WLL

问题描述 1. 环境&#xff1a; MathType7.4Microsoft Office 365Windows 11 2. 问题 情景1. Microsoft Word 启动时显示 Please reload Word to load MathType addin properly 情景2. 安装MathType后在 Microsoft Word 中使用复制粘贴时报错 运行时错误‘53’ 情景3. 在 M…

JavaScript 对象-三种创建对象的方式,遍历获取到对象。

JavaScript 对象-三种创建对象的方式&#xff0c;遍历获取到对象。 目录JavaScript 对象-三种创建对象的方式&#xff0c;遍历获取到对象。1. 对象1.1 什么是对象&#xff1f;1.2 为什么需要对象2. 创建对象的三种方式2.1 利用字面量创建对象2.2 利用new Object创建对象2.3 利用…

【数组】leetcode209.有序数组的平方(C/C++/Java/Js)

leetcode209.长度最小的子数组1 题目2 思路-滑动窗口3 代码3.1 C版本3.2 C版本3.3 Java版本3.4 JavaScript版本4 总结1 题目 题源链接 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl1, …, nu…

系列教程之《高铁上的GO》-第一篇

作者&#xff1a;坚果&#xff0c;OpenHarmony布道师&#xff0c;OpenHarmony校源行开源大使&#xff0c;CSDN博客专家&#xff0c;电子发烧友鸿蒙MVP&#xff0c;51CTO博客专家博主&#xff0c;阿里云博客专家。 本文主要讲解Go是什么&#xff0c;Go如何安装&#xff0c;开发G…

【Docker】(二)使用Dockerfile构建并发布一个SpringBoot服务

1.前言 在上一篇笔记 Docker基本概念与安装 中&#xff0c;我们已经获取到了一个Docker服务&#xff0c;并了解了Docker的基本组成及其各个组件的作用。 我们了解到&#xff0c;使用Docker的其中一个目的&#xff0c;是为了更加简单&#xff0c;方便的部署我们编写的服务&…

Typora下载和Markdown基础语法

本章内容如下&#xff1a; Typoar笔记下载资源及主题设置Markdown语法使用的基本方法 这篇博客一开始是为了教女朋友如何使用Typora和Markdown语法写的笔记&#xff0c;Markdown语法的内容不太全&#xff0c;只涉及基础使用。 文章目录Typora下载与主题设置Typora主题设置修改图…

在线考试答题系统的五大功能,你知道多少?

在线考试答题系统-五大功能&#xff0c;你知道多少&#xff1f;-在线考试答题系统优势&#xff1a;在线考试答题系统具有高度的可扩展性&#xff0c;高效灵活、功能强大。考试用户随时随地就可通过网络登录在线考试答题系统&#xff0c;参加在线报名、在线练习、在线考试、在线…