vue的基本概念与vue2的指令

news2025/1/20 17:08:04

目录

一、 Vue的基本概念

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

​        2、MVVM架构:

数据的双向绑定:

二、Vue开发的方式

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

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

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

​三、Vue的基本指令

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

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

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

(2)v-html:插入标签

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

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

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

(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交互

                变得非常简洁、方便。jQuery是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的实例可以直接访问

 <div id="root" class="root">
        <p>{{ msg }}</p>
        <button @click="changeMsg">请单击</button>
    </div>
    <div class="app">
        <p>{{ info }}</p>
    </div>
    
    <script>
        let flag = true;
        const vm = new Vue({
            el:'.root',
            data:{//定义属性
                msg:'Hello World!'
            },
            methods:{//定义方法
                changeMsg(){
                    if(flag){
                        this.msg = '钟楼';
                        flag = false;
                    }else{
                        this.msg = 'Hello World!';
                        flag = true;
                    }
                }
            }
        });
        new Vue({
            el:'.app',
            data: {
                info:'Hello 🐌!'
            }
        })
        console.log(vm.$data.msg);
    </script>

​三、Vue的基本指令

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

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

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

 <div id="app">
        <!-- v-show  -->
        <p v-show="flag">Hello 🐌</p>
        <p v-show="temp">钟楼</p>
        <button @click="change">单击</button>
    </div>
    
    <script>
        const vm = new Vue({
            el:"#app",
            data:{
                flag:true,
                temp: false
            },
            methods:{
                change(){
                    this.flag = !this.flag;
                    this.temp = !this.temp;
                }
            }
        });

        window.setInterval(()=>{
            vm.flag = !vm.flag;
            vm.temp = !vm.temp;
        },1000)
    </script>

(2)v-html:插入标签

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

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

  <div class="app">
        <div v-if="role==1">
            <h3>超级管理员</h3>
        </div>
        <div v-else-if="role==2">
            <h3>管理员</h3>
        </div>
        <div v-else>
            <h3>普通用户</h3>
        </div>
    </div>
    
    <script>
        const vm = new Vue({
            el:'.app',
            data:{
                role:2
            }
        })
    </script>

强调: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:循环指令,用于遍历数组、集合、对象的属性

 <!-- v-for 循环遍历数组与对象 -->
    <div class="app">
        <ul>
            <li v-for="item in arr">
                {{ item }}
            </li>
        </ul>
        <ul>
            <li v-for="(item,index) in arr">
                {{ index }} === {{ item }}
            </li>
        </ul>
        <ul>
            <li v-for="value in obj">
                {{ value }}
            </li>
        </ul>
        <ul>
            <li v-for="(value,key,index) in obj">
                {{ index }} -- {{ key }} -- {{ value }}
            </li>
        </ul>
        <ul>
            <li v-for="item in objArr">
                {{item.id}}
                {{item.name}}
                {{item.address}}
            </li>
        </ul>
        <table>
            <thead>
                <tr>
                    <th>编号</th>
                    <th>姓名</th>
                    <th>地址</th>
                </tr>
            </thead>
            <tbody>
                <tr v-for="item in objArr">
                    <td>{{ item.id }}</td>
                    <td>{{ item.name }}</td>
                    <td>{{ item.address }}</td>
                </tr>
            </tbody>
        </table>
    </div>

    <script>
        const vm = new Vue({
            el:'.app',
            data:{
                arr:[11,22,33,44,55],//数组
                obj:{
                    id:1001,
                    name:'A1',
                    address:'西安'
                },
                objArr:[
                    {
                        id:1001,
                        name:'A1',
                        address:'西安'
                    },
                    {
                        id:1002,
                        name:'A2',
                        address:'咸阳' 
                    },
                    {
                        id:1003,
                        name:'A3',
                        address:'商洛' 
                    },
                    {
                        id:1004,
                        name:'A4',
                        address:'宝鸡'
                    }
                ]
            }
        })
    </script>

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

 

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

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

<!-- input的值和变量进行绑定,实现数据与视图的双向绑定 -->
    <div class="app">
        <!-- 单选 -->
        <p>性别:</p>
        <input type="radio" name="sex" id="man" v-model="gender" value="男">
        <label for="man">男</label>
        <input type="radio" name="sex" id="woman" v-model="gender" value="女">
        <label for="woman">女</label>
        <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 for="userName">姓名:</label>
        <input type="text"  id="userName" v-model="userName">
        <br>
        <p>
            你的姓名:{{ userName }}
        </p>
      
    </div>

    <script>
        const vm = new Vue({
            el:'.app',
            data:{
                gender:'',
                book:'',
                hobby:[],
                userName:''
            }
        })

    </script>

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

  <div id="app">
        <h4>v-once示例</h4>
        <input type="text" v-model="onceValue">
        <p>
            第一个:{{ onceValue }}
        </p>
        <p v-once>
            第二个:{{ onceValue }}
        </p>
    </div>

    <script>
        const vm= new Vue({
            el:'#app',
            data:{
                onceValue:'v-once绑定'
            }
        })
    </script>

 

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

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

相关文章

智能网 联汽车信息安全发展趋势

智能网 联汽车信息安全发展趋势 智能网联汽车行业发展 根据工信部发布的《国家车联网产业标准体系建设 指南&#xff08;智能网联汽车&#xff09;》的定义&#xff0c;智能网联汽车是指搭载先进的车载传感器 、控制器、执行器等装置&#xff0c;并融合现代通信与网络技术&a…

Android设计模式详解之备忘录模式

前言 备忘录模式是一种行为模式&#xff0c;该模式用于保存对象当前状态&#xff0c;并且在之后可以再次恢复到此状态&#xff1b; 定义&#xff1a;在不破坏封闭的前提下&#xff0c;捕获一个对象的内部状态&#xff0c;并在该对象之外保存这个状态&#xff0c;这样&#xf…

【单目3D目标检测】MonoDLE论文精读与代码解析

文章目录PrefaceAbstractContributionsDiagnostic ExperimentsPipelineRevisiting Center DetectionTraining SamplesIoU Oriented OptimizationExperimental ResultsPreface [CVPR2021] Ma X, Zhang Y, Xu D. Delving into localization errors for monocular 3d object detec…

Docker技术原理

一、Docker架构 Docker包括三个基本概念&#xff1a; 镜像&#xff08;Image&#xff09;: Docker 镜像&#xff08;Image&#xff09;&#xff0c;就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。容器…

vue中使用tinymce富文本编辑器

之前都是用的quill富文本&#xff0c;但是因为要实现添加表格的功能&#xff0c;quill没有tinymce强大&#xff0c;所以改用了tinymce。当时也是百度了一堆的教程可是没有记录下来&#xff0c;现在发现有的细节忘记了&#xff0c;所以这个文章可能会有错误 。 当时看了好几个安…

全球智能网联汽车出货量预计

IDC 于 2020 年最新发布的《全球智能网 联汽车预测报告&#xff08;2020-2024&#xff09;》数据显示&#xff0c;尽管受新冠肺炎疫情冲击&#xff0c;2020 年全球智能网联汽车出货量预计较上一年下滑 10.6%&#xff0c;约为 4440 万辆&#xff0c;但到 2024 年全球智能网联汽车…

数据可视化之excel和finebi报表实现对比

当我们拿到数据&#xff0c;想对数据实现可视化报表设计。第一步就是要了解什么是数据可视化分析&#xff0c;且数据可视化分析的方法有什么&#xff1f;而且当我们拿到excel表格的数据&#xff0c;第一个想法是excel表格自身实现报表数据可视化&#xff0c;除了用excel本身实现…

JMeter

Apache JMeter—压力测试工具 一.什么是Apache JMeter Apache JMeter 是 Apache 组织基于 Java 开发的压力测试工具&#xff0c;用于对软件做压力测试。 JMeter 最初被设计用于 Web 应用测试&#xff0c;但后来扩展到了其他测试领域&#xff0c;可用于测试静态和动态资源&am…

Linux-redis 集群配置

1、redis主从复制(Master/Slave) a、集群结构 三个节点&#xff1a;一个主节点&#xff0c;二个从节点 b、准备实例和配置 在虚拟机开启3个redis 实例&#xff0c;来模拟主从集群模式&#xff0c;信息如下&#xff1a; ippost角色192.168.150.1017001master192.168.150.101…

服务器硬件规格常用查看命令——HCA卡相关命令

使用不同厂商的InfiniBand设备&#xff0c;可能需要到不同厂商的官网下载相应的工具包&#xff0c; Matrox的HCA卡操作命令由infiniband-diags-1.6.5.MLNX20150902.0e83419-0.1.x86_64工具 包提供。由于这类工具的功能与厂商有关&#xff0c;且是针对特定设备的&#xff0c;所以…

融云CEO董晗:国产化进程加速,助推政企数智办公平台深化发展

政策催化加疫情助推下&#xff0c;办公线上化迅速完成着市场教育已经成为当前的主流趋势。而随着“国产化”成为各行业数字化发展道路上的关键词&#xff0c;政企办公领域国产替代的发展确定性更加凸显。关注【融云全球互联网通信云】了解更多 近期&#xff0c;融云与艾瑞咨询…

SpringBoot基础篇和运维篇

目录 parent starter 引导类 ​编辑 辅助功能 REST开发 REST简介 入门案例&#xff1a; 1、设置http请求方式​编辑 2、设置请求参数 知识点&#xff1a; 1&#xff0c;RequestMapping 2、PathVariable注解 3、三个有关页面请求参数的注解 4、REST风格的注解简化&…

基于数字孪生技术在水电站的探索应用

数字孪生技术作为一种新的技术趋势&#xff0c;日益被千行百业产业所重视。那么&#xff0c;是否可以使用数字孪生技术来构建一个数字孪生水电站&#xff1f;让传统的水电行业也能把握住最新的数字技术的发展趋势&#xff0c;促进水电事业的发展呢。 基于数字孪生技术在水电站 …

三、解构赋值、函数默认值、数组解构、对象解构

三、解构赋值、函数默认值、数组解构、对象解构 函数传参为undefined/不传值&#xff0c;解构赋值时值为undefined/不传值时&#xff0c;都可以去取自己定义的默认值。 一、函数默认值 1.1 函数默认值 ES5语法函数参数赋默认值 function foo(a, b){var a typeof(argument…

11.Linux文件管理命令---diff比较两个文件

11.Linux文件管理命令—diff比较两个文件 文章目录diff比较两个文件练习案例diff比较两个文件 作用&#xff1a;找出两个文件的不同点。 用法&#xff1a;diff [选项] 源文件 目标文件 主要选项如下。 下面是 GNU 所接受的 diff 所有选项的概要。大多数选项有两个相同的名字&…

单机模拟集群(三主两从)

引言 操作系统环境&#xff1a;Ubuntu 20.04 Redis版本&#xff1a;6.2.8 准备工作 如果已经安装过了&#xff0c;找到自己的安装路径。如果没有安装过&#xff0c;去官网下载 当前最新版本是7.0&#xff0c;我这里用的是6.0&#xff0c;下载 redis-6.2.8.tar.gz&#xff0c…

CAPL学习之路-测试功能集函数(测试报告部分)

测试功能集函数用于测试用例的实现,主要使用场景在test module和test unit模块的capl中 。所以千万不要在网络节点的CAPL脚本中使用,不然会报错。比如TestWaitForTimeout()函数,等待指定的时间 在网络节点的capl脚本中使用时会报错: 在test module节点的capl脚本中使用时正…

SpreadJS集算表联动数据透视表,高效实现前端数据多维分析

在做一些财务、供应链、资产管理等系统时&#xff0c;由于业务人员线下都是采用Excel来完成的&#xff0c;因此就需要将Excel中业务人员使用的功能都能在Web端系统实现&#xff0c;整体上的实现方案有三种&#xff1a; 完全自研一套具备Excel功能的组件&#xff1b;使用成品软…

Linux-tar打包与解压命令

tar命令位于/bin目录下&#xff0c;它能够将用户所指定的文件或目录打包成一个文件&#xff0c;但不做压缩。一般Linux上常用的压缩方式是选用tar将许多文件打包成一个文件&#xff0c;再以gzip压缩命令压缩成xxx.tar.gz(或称为xxx.tgz)的文件。 常用参数&#xff1a; -c&a…

布隆过滤器【美与不美之谈】

什么是布隆过滤器 布隆过滤器其实本质上来讲就是一种巧妙的数据结构&#xff0c;特点就是高效的插入和查询。 它能告诉我们&#xff1a;什么一定不存在&#xff0c;或者什么可能会存在 总结&#xff1a;布隆过滤器是概率性的。它只能告诉我们什么一定不存在&#xff0c;或者…