内置指令(Vue2版)

v-bind指令

1、作用:动态设置html的标签属性:src url title...

2、语法:v-bind:属性名 = "表达式"

3、简写形式 :属性名 = "表达式"

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <img :src="image" alt="">
        <img v-bind:src="image" alt="">
    </div>
    <script>
        const app = new Vue({
            el:'#app',
            data:{
                image:""
            }
        })
    </script>
</body>
</html>

 v-if指令

1、作用:控制元素显示隐藏(条件渲染)

2、语法:v-if="表达式" 表达式值true显示,false隐藏

3、原理:基于条件判断,是否创建或移除元素节点

4、场景:要么显示,要么隐藏,不频繁切换的场景

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="app"  v-if="isShow">
        <h3>{{msg}}</h3>
        <a href="https://www.baidu.com/">点击登录</a>
        <h1 @click="ChangeShow">x</h1>
    </div>
    <script>
        const app = new Vue({
            el:'#app',
            data:{
                msg:"为方便您购买,请提前登录",
                isShow:true
            },
            methods: {
                ChangeShow(){
                    this.isShow=!this.isShow
                }
            }
        })
    </script>
    <style>
        #app{
            background-color: aqua;
            display: flex;
            align-items: center;
            justify-content: space-around;
        }
    </style>
</body>
</html>

v-else/v-else-if指令

1、作用:辅助v-if进行判断渲染

2、语法:v-else/v-else-if="表达式"

3、注意:需要紧挨着v-if一起使用

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <h3 v-if="gender == 1">男</h3>
        <h3 v-else="gender == 2">女</h3>
        <h4 v-if="score >= 90 ">成绩评定A:奖励电脑一台</h4>
        <h4 v-else-if="score >= 70 ">成绩评定B:奖励周末旅游</h4>
        <h4 v-else-if="score >= 60 ">成绩评定C:奖励零食礼包</h4>
        <h4 v-else="score < 60 ">成绩评定D:惩罚一周不能玩手机</h4>
    </div>
    <script>
        const app = new Vue({
            el: '#app',
            data: {
                gender: 1,
                score: 60
            }
        })
    </script>
    <style>
        #app {
            background-color: rgb(17, 197, 173);
        }
    </style>
</body>
</html>

v-for指令

1、作用: 基于数据循环, 多次渲染整个元素 → 数组、对象、数字...
2. 遍历数组语法: v-for = "(item, index) in 数组"
(1) item 每一项, index 下标
(2)省略 index: v-for = "item in 数组"

v-for 中的 key

语法:key属性 = "唯一标识"
作用:给列表项添加的唯一标识。便于Vue进行列表项的正确排序复用
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <p v-for="item in list">我是一个内容</p>
    </div>
    <script>
        const app = new Vue({
            el:'#app',
            data:{
                list:[0,1,2,3,4,5,6]
            }
        })
    </script>
</body>
</html>

v-html指令

作用:设置元素的 innerHTML
语法:v-html = "表达式 "
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <h3  v-html="str"></h3>
        <a v-html="s"></a>
    </div>
    <script>
        const app = new Vue({
            el:'#app',
            data:{
                str:"<a href='https://blog.csdn.net/zl18603543572'>早起的年人的文章</a>",
                s:"<h3>我是你爸爸</h3>"
            }
        })
    </script>
</body>
</html>

v-model指令

1. 作用: 给 表单元素 使用, 双向数据绑定 → 可以快速 获取 或 设置 表单元素内容
① 数据变化 → 视图自动更新
② 视图变化 → 数据自动更新
2. 语法: v-model = '变量'
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        用户:<input v-model="name" type="text">
        <br>
        密码:<input v-model="password" type="text">
        <div>
            <button @click="load">登录</button>
            <button @click="reset">重置</button>
        </div>
    </div>
    <script>
        const app = new Vue({
            el: '#app',
            data: {
                name: '',
                password: ''
            },
            methods: {
                load() {
                    if (this.name == '') {
                        alert('请输入您的用户名')
                    } else if (this.password == '') {
                        alert('请输入您的密码')
                    } else {
                        alert(this.name + ",恭喜您登陆成功!");
                    }
                },
                reset() {
                    this.name = ''
                    this.password = ''
                    if (this.name == "" && this.password == "") {
                        alert("重置成功!")
                    }
                }
            },
        })
    </script>
</body>
</html>

v-on指令

1. 作用: 注册事件 = 添加监听 + 提供处理逻辑
2. 语法:
① v-on:事件名 = "内联语句"
② v-on:事件名 = "methods中的函数名"
3. 简写:@事件名
4. 注意:methods函数内的 this 指向 Vue 实例
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <button v-on:click="add">+1</button>
        <h3>{{count}}</h3>
        <button @click="sub">-1</button>
    </div>
    <script>
        const app = new Vue({
            el: '#app',
            data: {
                count: 100
            },
            methods: {
                add(){
                    this.count+=1
                },
                sub(){
                    this.count-=1
                }
            },
        })
    </script>
</body>
</html>

v-show指令

1、作用:控制元素显示隐藏

2、语法:v-show="表达式" 表达式true显示,false隐藏

3、原理:切换display:none控制隐藏

4、场景:频繁切换显示隐藏的场景

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <h3 v-show="isShow">hahahah</h3>
        <button @click="getShow">点击显示</button>
        <button v-on:click="getNonShow">点击隐藏</button>
    </div>
    <script>
        const app = new Vue({
            el:'#app',
            data:{
                isShow:false
            },
            methods: {
                getShow(){
                    this.isShow=!this.isShow
                },
                getNonShow(){
                    this.isShow=!this.isShow
                }
            },
        })
    </script>
</body>
</html>

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值