vue.js -- 模板语法

插值表达式

插值表达式是数据绑定最常见的形式就是使用 {{ }} 语法的文本插值,{{ }} 将会被替代为对应组件实例中 content property 的值。无论何时,绑定的组件实例上content property 发生了改变,插值处的内容都会更新。

代码演示:

<!DOCTYPE html>
<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>vue.js -- 模板语法</title>
    <script src="https://unpkg.com/vue@next"></script>
</head>
<body>
    <div id="root"></div>
    <script>
        const app = Vue.createApp({
            data(){
                return {
                    content: 'Hello Vue.js!'
                }
            },
            template: `<div>{{content}}</div>`
        })
        const vm = app.mount('#root');
    </script>
</body>
</html>

页面效果:
在这里插入图片描述

v-once

v-once 只渲染一次,当数据改变时,插值处的内容不会更新。

代码演示:

<body>
    <div id="root"></div>
    <script>
        const app = Vue.createApp({
            data(){
                return {
                    content: 'Hello Vue.js!'
                }
            },
            template:'<div v-once>{{content}}</div>'
        })
        const vm = app.mount('#root');
    </script>
</body>

页面效果:
在这里插入图片描述

v-html

插值表达式会将数据解释为普通文本,而非 HTML 代码。为了输出真正的 HTML代码,需要使用 v-html

v-html 有XSS风险,会覆盖子组件

使用插值表达式代码演示:

<body>
    <div id="root"></div>
    <script>
        const app = Vue.createApp({
            data(){
                return {
                    content: '<b>Hello Vue.js!</b>'
                }
            },
            template:'<div>{{content}}</div>'
        })
        const vm = app.mount('#root');
    </script>
</body>

页面效果:
在这里插入图片描述

使用v-html代码演示:

<body>
    <div id="root"></div>
    <script>
        const app = Vue.createApp({
            data(){
                return {
                    content: '<b>Hello Vue.js!</b>'
                }
            },
            template:'<div v-html="content"></div>'
        })
        const vm = app.mount('#root');
    </script>
</body>

页面效果:
在这里插入图片描述

v-bind

v-bind用于绑定数据和元素属性。

v-bind:title可以缩写成:title

代码演示:

<body>
    <div id="root"></div>
    <script>
        const app = Vue.createApp({
            data(){
                return {
                    content: 'Hello Vue.js!'
                }
            },
            template:'<div :title="content">{{content}}</div>'
        })
        const vm = app.mount('#root');
    </script>
</body>

页面效果:
在这里插入图片描述

动态参数

代码演示:

        const app = Vue.createApp({
            data(){
                return {
                    content: 'Hello Vue.js!',
                    name: 'title'
                }
            },
            template:'<div :[name]="content">{{content}}</div>'
        })

页面效果:
在这里插入图片描述

v-on

v-on用于绑定事件

v-on:click可以缩写成@click

代码演示:

        const app = Vue.createApp({
            data(){
                return {
                    content: 'Hello Vue.js!',
                    event:'click'
                }
            },
            methods:{
                handleClick(){
                    alert('handlClick');
                }
            },
            template:'<div @[event]="handleClick">{{content}}</div>'
        })

页面效果:
在这里插入图片描述

修饰符

修饰符是以.指明的特殊后缀,用于指出一个指令应该以特殊方式绑定。

例如,.prevent 修饰符对于触发的事件调用 event.preventDefault();

代码演示:

  const app = Vue.createApp({
            data(){
                return {
                    content: 'Hello Vue.js!'
                }
            },
            methods:{
                handleClick(e){
                    // e.preventDefault();
                }
            },
            template: `
                <form action="https://cn.bing.com" @click.prevent="handleClick">
                    <button type="submit">提交</button>
                </form>
                `
        })

页面效果:
在这里插入图片描述

点击提交无任何变化,跳转被阻止。

(完)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱划水de鲸鱼哥~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值