Vue笔记(七)内置指令与自定义指令

常用内置指令
 
  •     v-show : 通过控制 display 样式来控制显示/隐藏
  •     v:text : 更新元素的 textContent
  •     v-html : 更新元素的 innerHTML
  •     v-if : 如果为 true, 当前标签才会输出
  •     v-else: 如果为 false, 当前标签才会输出到页面
  •     v-for : 遍历数组/对象
  •     v-on : 绑定事件监听, 一般简写为@
  •     v-bind : 强制绑定解析表达式, 可以省略 v-bind
  •     v-model : 双向数据绑定
  •     ref : 指定唯一标识, vue 对象通过$els 属性访问这个元素对象
  •     v-cloak : 防止闪现, 与 css 配合: [v-cloak] { display: none }

自定义指令
1) 注册全局指令
Vue.directive('my-directive', function(el, binding)
{ el.innerHTML = binding.value.toupperCase() })

2) 注册局部指令
directives : { 'my-directive' : { bind (el, binding)
{ el.innerHTML = binding.value.toupperCase() } } }

3) 使用指令 v-my-directive='xxx'

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script type="text/javascript" src="./js/vue.min.js"></script>
    <style>
        [v-cloak] {
            display: none
        }
    </style>
</head>

<body>
    <div id="test">
        <p v-text="url"></p>
        <p v-html="url"></p> <img :id="myid" :src="imageSrc">
        <p><span ref="message">atguigu.com</span> <button @click="showMsg">显示左侧文本</button> </p>
        <p v-cloak>{{url}}</p>
</body>
<script type="text/javascript" src="https://cdn.bootcss.com/moment.js/2.19.0/moment.js"></script>
<script>
    alert('模拟加载慢') 
    new Vue({
        el: '#test',
        data: {
            url: '<a href="http://www.atguigu.com">尚硅谷</a>',
            myid: 'abc123',
            imageSrc: 'http://cn.vuejs.org/images/logo.png'
        },
        methods: {
            showMsg: function () {
                alert(this.$refs.message.textContent)
            }
        }
    })
</script>

</html>

 

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script type="text/javascript" src="./js/vue.min.js"></script>
</head>

<body>
    <div id="demo1">
        <p v-upper-text="msg"></p>
        <p v-lower-text="msg"></p>
    </div>
    <div id="demo2">
        <p v-upper-text="msg2"></p>
        <p v-lower-text="msg2"></p>
        <!--局部指令, 此处不能使用-->
    </div>
</body>
<script>
    //注册全局指令 
    Vue.directive('upper-text', function (el, binding) {
        el.innerHTML = binding.value.toUpperCase()
    })
    new Vue({
        el: '#demo1',
        data: {
            msg: 'NBA love this game!'
        },
        directives: { // 注册局部指令 
            'lower-text': {
                bind(el, binding) {
                    el.innerHTML = binding.value.toLowerCase()
                }
            }
        }
    })
    new Vue({
        el: '#demo2',
        data: {
            msg2: 'I Like You'
        }
    })
</script>

</html>

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值