Vue的常见指令

目录

1.v-bind

2. class绑定

3.style绑定

4.v-if/v-show

 


1.v-bind

        v-bind指令用于绑定属性 可以简写成 “   :”

        它的作用就是我们可以动态的定义属性的值,比如常见的<img src = "1.jpg">

        我们如果想要修改图片就需要获取到DOM对象,然后再重新填充,但是如果使用v-bind,

        我们就可以动态的生成src属性值。

下面我们将实现图片切换的效果:

<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>

  <div id="app" >
    <img v-bind:src = "path" :style="{width:width , height:height}">
    <br>
    <button @click = "change()">切换图片</button>
  </div>
  
  <script type="text/javascript" src="vue.global.js"></script>
  <script>
    // 1.创建app
    const app = Vue.createApp({
      // data: option api
      data: function() {
        return {
          path:"images/1.jpg",
          width:100,
          height:100
        }
      },
      methods:{
        change(){
            if(this.path==="images/1.jpg"){
                this.path = "images/2.jpg"
            }else{
                this.path = "images/1.jpg"
            }
            
        }
      }
    })

    // 2.挂载app
    app.mount("#app")
  </script>
</body>
</html>

它的逻辑关系如下:

所以说,vue主要是实现对数据的操作,而js是对DOM对象的操作

 

2. class绑定

        class是表示类选择器,常用的还有id选择器等。

        v-bind同样可以绑定class,只是写法略有不同。

        接下来,我们实现经常在网页上看见的多选项选择时,选到哪个,哪个就会高亮显示。

        代码如下:

<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>

    <style>
        li{
            width: 50px;
            height: 25px;
            display: block;
            float: left;
            background-color: #999;
            border: 1px solid;
            padding-left: 5px;
        }

        .red{
            background-color: red;
        }
    </style>

  <div id="app">
    <ul>
        <li :class="{red:num==1}" @click = "change(1)">选项1</li>
        <li :class="{red:num==2}" @click = "change(2)">选项2</li>
        <li :class="{red:num==3}" @click = "change(3)">选项3</li>
    </ul>
  </div>
  
  <script type="text/javascript" src="vue.global.js"></script>
  <script>
    // 1.创建app
    const app = Vue.createApp({
      // data: option api
      data: function() {
        return {
          num:1
        }
      },

      methods:{
        change(num){
            this.num = num
        }
      }
    })

    // 2.挂载app
    app.mount("#app")
  </script>
</body>
</html>

        执行逻辑如下:

3.style绑定

        style表示样式,同样我们也可以用vue绑定style,实现样式属性的动态生成。

我们实现一个按钮控制一个div盒子的长宽高,颜色等样式,示例如下:

<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
    <style>
        li{
            width: 40px;
            height: 20px;
            border: 2px , solid;
            background-color: #999;
            float: left;
            display: block;
        }

        #context{
            clear: both;
            border: 1px solid;
            width: 100px;
            height: 100px;
            background-color: aqua;
            margin-left: 40px;
        }
        li:hover{
            background-color: red;
        }
       
    </style>

  <div id="app">
    <ul>
        <li @click = "change(0)">变宽</li>
        <li @click = "change(1)">变高</li>
        <li @click = "change(2)">变色</li>
        <li @click = "change(3)">隐藏</li>
        <li @click = "change(4)">重置</li>
    </ul>
    <div id="context"  :style="{width:width , height:height,'background-color':color,display:none}">
    </div>
  </div>
  
  <script type="text/javascript" src="../vue.global.js"></script>
  <script>
    // 1.创建app
    const app = Vue.createApp({
      // data: option api
      data: function() {
        return {
          width:100 , 
          height:100 , 
          color:'aqua' , 
          none:'block'
        }
      },
      methods:{
        change(num){
            if(num==0){
                this.width = this.width+10
            }
            if(num==1){
                this.height = this.height+10
            }
            if(num ==2){
                this.color = 'red' ; 
            }
            if(num==3){
                this.none = 'none' ; 
            }
            if(num==4){
                this.width = 100 ; 
                this.height = 100 ; 
                this.color = 'aqua';
                this.none = 'block'
            }
        }
      }
    })

    // 2.挂载app
    app.mount("#app")
  </script>
</body>
</html>

 实现逻辑:

效果展示:

4.v-if/v-show

        v-if 指令 条件渲染.如果条件为true,那么它会生成一个DOM元素并且插入;

        如果为false,那么直接连DOM元素都不生成。

        v-show作用和v-if一样,只是当它为true或者false都会生成DOM对象;

        只是当然为false时,会把DOM对象隐藏起来。

示例:实现点击哪个按钮显示对应的内容,其他的内容会被隐藏,效果如下:

实现代码如下:

<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>使用v-if实现元素的显示与隐藏</title>
</head>
<body>
    <style>
        .red{
            background-color: red;
        }
        ul , li{
           
            float: left;
            display: block;
            margin-left: 10px;
            background: color #999;
            
        }

        li{
            border: 1px red;
            height: 30px;
            width: 100px;
            text-align: center;
        }
        li:hover{
            background-color: red;
        }
        #context{
           clear: both;
        }
    </style>

  <div id="title">
    <ul>
        <li :class="{red:flag==0}" @click ="change(0)">清纯男大</li>
        <li :class="{red:flag==1}" @click="change(1)">油腻骚男</li>
        <li :class="{red:flag==2}" @click="change(2)">怀院校草</li>
    </ul>
    
        <ul id="context">
            <li v-if="flag==0">刘驰宇</li>
            <li v-if="flag==1">李杭涛</li>
            <li v-show="flag==2">黄嘉乐</li>
        </ul>
  </div>

  
  
  <script type="text/javascript" src="../vue.global.js"></script>
  <script>
    // 1.创建app
    const app = Vue.createApp({
        
      // data: option api
      data: function() {
        return{
           
            flag : 0
        }
      },
      
      methods:{
        change(flag){
            this.flag = flag;
        
        }
      }
    })

    // 2.挂载app
      app.mount("#title")


  </script>
</body>
</html>

主要逻辑如下:

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Nginx:关于实现跨域代理

运维专题 Nginx&#xff1a;关于实现跨域代理 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:https://blog.csdn.ne…

科普文:分布式系统的架构设计模式

一、分布式架构基本概念 分布式架构是一种计算机系统设计方法&#xff0c;它将一个复杂的系统划分为多个自治的组件或节点&#xff0c;并通过网络进行通信和协作。每个组件或节点在功能上可以相互独立&#xff0c;但又能够通过消息传递或共享数据来实现协同工作。分布式架构主要…

为什么独立站需要高质量的GPB外链?

独立站需要高质量的GPB外链&#xff0c;主要是因为它们能显著提升网站的可信度和可见性。高质量的外链相当于得到其他权威网站的认可和推荐&#xff0c;这会让搜索引擎认为你的内容有价值&#xff0c;从而提升你的搜索排名。试想一下&#xff0c;当其他有影响力的网站愿意链接到…

设计模式7-装饰模式

设计模式7-装饰模式 写在前面动机模式定义结构代码推导原始代码解决问题分析 选择装饰模式的理由1. 职责分离&#xff08;Single Responsibility Principle&#xff09;2. 动态扩展功能3. 避免类爆炸4. 开闭原则&#xff08;Open/Closed Principle&#xff09;5. 更好的组合复用…

如何忽略部分文件或者文件夹在git提交项目时

嗨&#xff0c;我是兰若&#xff0c;最近发现有些小伙伴在提交代码时&#xff0c;总是把不该提交的文件&#xff0c;比如说本地批跑的缓存文件给提交到了git上面&#xff0c;导致别人在拉取代码的时候&#xff0c;也会把这部分文件拉取到自己本地&#xff0c;从而导致和本地的缓…

深度学习(笔记内容)

1.国内镜像网站 pip使用清华源镜像源 pip install <库> -i https://pypi.tuna.tsinghua.edu.cn/simple/ pip使用豆瓣的镜像源 pip install <库> -i https://pypi.douban.com/simple/ pip使用中国科技大学的镜像源 pip install <库> -i https://pypi.mirro…

PyCharm如何安装requirements.txt中的依赖包

问题&#xff1a;下载别人的源码&#xff0c;如何安装代码中requirement.txt中的依赖包。 解决方案&#xff1a; &#xff08;1&#xff09;打开PyCharm下面的Terminal&#xff0c;先为代码创建单独的虚拟环境并进入到虚拟环境中&#xff08;每个项目单独的环境&#xff0c;这…

HINet: Half Instance Normalization Network for Image Restoration

论文&#xff1a;HINet: Half Instance Normalization Network for Image Restoration Abstract&#xff1a; 在本文中&#xff0c;我们探讨了实例归一化在低级视觉任务中的作用。 具体来说&#xff0c;我们提出了一个新颖的块&#xff1a;半实例归一化块&#xff08;HIN 块&…

Oracle 19c 统一审计表清理

zabbix 收到SYSAUX表空间告警超过90%告警&#xff0c;最后面给出的清理方法只适合ORACLE 统一审计表的清理&#xff0c;传统审计表的清理SYS.AUD$不适合&#xff0c;请注意。 SQL> Col tablespace_name for a30 Col used_pct for a10 Set line 120 pages 120 select total.…

Linux系统下的用户管理模式

Linux系统下的用户管理模式 本文以属于Linux系统基本概念&#xff0c;如果以查找教程教程&#xff0c;解决问题为主&#xff0c;只需要查看本文后半部分。 如需要系统性学习请查看本文前半部分。 文章目录 Linux系统下的用户管理模式1. Linux下用户的概念2. 创建不同类型的用户…

C++继承(一文说懂)

目录 一&#xff1a; &#x1f525;继承的概念及定义1.1 继承的概念1.2 继承定义1.2.1 定义格式1.2.2 继承关系和访问限定符1.2.3 继承基类成员访问方式的变化 二&#xff1a;&#x1f525;基类和派生类对象赋值转换三&#xff1a;&#x1f525;继承中的作用域四&#xff1a;&a…

SpringSecurity中文文档(Servlet Authorization Architecture )

Authorization 在确定了用户将如何进行身份验证之后&#xff0c;还需要配置应用程序的授权规则。 Spring Security 中的高级授权功能是其受欢迎的最有说服力的原因之一。无论您选择如何进行身份验证(无论是使用 Spring Security 提供的机制和提供者&#xff0c;还是与容器或其…

基于单片机的空调控制器的设计

摘 要 &#xff1a; 以单片机为核心的空调控制器因其体积小 、 成本低 、 功能强 、 简便易行而得到广泛应用 。 本设计通过 &#xff21;&#xff34;&#xff18;&#xff19;&#xff33;&#xff15;&#xff12; 控制&#xff24;&#xff33;&#xff11;&#xff18;&a…

基于YOLOv9的脑肿瘤区域检测

数据集 脑肿瘤区域检测&#xff0c;我们直接采用kaggle公开数据集&#xff0c;Br35H 数据中已对医学图像中脑肿瘤位置进行标注 数据集我已经按照YOLO格式配置好&#xff0c;数据内容如下 数据集中共包含700张图像&#xff0c;其中训练集500张&#xff0c;验证集200张 模型训…

全网最适合入门的面向对象编程教程:11 类和对象的Python实现-子类调用父类方法-模拟串口传感器和主机

全网最适合入门的面向对象编程教程&#xff1a;11 类和对象的 Python 实现-子类调用父类方法-模拟串口传感器和主机 摘要&#xff1a; 本节课&#xff0c;我们主要讲解了在 Python 类的继承中子类如何进行初始化、调用父类的属性和方法&#xff0c;同时讲解了模拟串口传感器和…

【问题记录】Nodeclub运行make install报错npm ERR! code ELIFECYCLE

问题展示 按照官网给出的教程进行到make install这一步卡住了&#xff0c;显示了如下报错。 解决方法 将node.js版本变更为能够识别代码的版本&#xff0c;我将版本修改成了16.14.0以后成功运行。 nvm install 16.14.0

Java设计模式---(创建型模式)工厂、单例、建造者、原型

目录 前言一、工厂模式&#xff08;Factory&#xff09;1.1 工厂方法模式&#xff08;Factory Method&#xff09;1.1.1 普通工厂方法模式1.1.2 多个工厂方法模式1.1.3 静态工厂方法模式 1.2 抽象工厂模式&#xff08;Abstract Factory&#xff09; 二、单例模式&#xff08;Si…

从零开始做题:好怪哦

题目 给出一个压缩文件 解题 方法1 01Edit打开&#xff0c;发现是个反着的压缩包&#xff08;末尾倒着的PK头&#xff09; import os# 目标目录路径 # target_directory /home/ai001/alpaca-lora# 切换到目标目录 # os.chdir(target_directory)# 打印当前工作目录以确认…

前端开发过程中经常遇到的问题以及对应解决方法 (持续更新)

我的朋友已经工作了 3 年&#xff0c;他过去一直担任前端工程师。 不幸的是&#xff0c;他被老板批评了&#xff0c;因为他在工作中犯了一个错误&#xff0c;这是一个非常简单但容易忽视的问题&#xff0c;我想也是很多朋友容易忽视的一个问题。 今天我把它分享出来&#xff…

前端面试题27(在实际项目中,如何有效地利用Vue3的响应式系统提高性能?)

在实际项目中&#xff0c;有效利用Vue3的响应式系统提高性能主要涉及以下几个关键点&#xff1a; 1. 合理使用reactive和ref reactive&#xff1a;用于将复杂的数据结构&#xff08;如对象或数组&#xff09;转换成响应式版本。确保只将需要实时更新的数据结构声明为响应式&am…